1 <sect1 id="zend.feed.custom-feed">
2 <title>מחלקות סנדקציה מותאמות אישית</title>
5 לבסוף, ניתן להרחיב את מחלקות ה <code>Zend_Feed</code> אם תרצה להזין ולספק פורמט מותאם אישית שלך, או להוסיף פונקציונליות מדוייקת יותר לניהול ותפעול של אלמנטים.
9 הנה דוגמא למחלקה מותאמת אישית לניהול תגי Atom אשר מטפלת בתגיות <code>myns:</code> בעצמה.
10 דע שזה גם מבצע את הקריאה אל <code>registerNamespace()</code>, כדי שהמשתמש הסופי לא יצטרך לדאוג לגבי שם התגית הזאת.
13 <example id="zend.feed.custom-feed.example.extending">
14 <title>הרחבת מחלקת ניהול הסנדקציה של Atom</title>
15 <programlisting role="php"><![CDATA[
17 * The custom entry class automatically knows the feed URI (optional) and
18 * can automatically add extra namespaces.
20 class MyEntry extends Zend_Feed_Entry_Atom
23 public function __construct($uri = 'http://www.example.com/myfeed/',
26 parent::__construct($uri, $xml);
28 Zend_Feed::registerNamespace('myns',
29 'http://www.example.com/myns/1.0');
32 public function __get($var)
36 // Translate myUpdated to myns:updated.
37 return parent::__get('myns:updated');
40 return parent::__get($var);
44 public function __set($var, $value)
48 // Translate myUpdated to myns:updated.
49 parent::__set('myns:updated', $value);
53 parent::__set($var, $value);
57 public function __call($var, $unused)
61 // Translate myUpdated to myns:updated.
62 return parent::__call('myns:updated', $unused);
65 return parent::__call($var, $unused);
72 אז כדי להשתמש במחלקה זו, יהיה צורך רק בליצור אובייקט שלה ולקרוא לערך <code>myUpdated</code>:
74 <programlisting role="php"><![CDATA[
75 $entry = new MyEntry();
76 $entry->myUpdated = '2005-04-19T15:30';
78 // method-style call is handled by __call function
80 // property-style call is handled by __get function