{"id":497,"date":"2011-09-14T10:07:03","date_gmt":"2011-09-14T08:07:03","guid":{"rendered":"http:\/\/www.capri-soft.de\/blog\/?p=497"},"modified":"2011-09-14T10:08:25","modified_gmt":"2011-09-14T08:08:25","slug":"adobe-flex-3-multi-filterfunction-auf-mxarraycollection","status":"publish","type":"post","link":"https:\/\/www.capri-soft.de\/blog\/?p=497","title":{"rendered":"Adobe Flex 3: Multi-FilterFunction auf mx:ArrayCollection"},"content":{"rendered":"<h1>Aufgabenstellung<\/h1>\n<p>Es wird eine Datenstruktur ben\u00f6tigt, die mehrere FilterFunctions unterst\u00fctzt und mit der mx:ArrayCollection kompatibel ist.<\/p>\n<h1>Problem<\/h1>\n<p>mx:ArrayCollection besitzt nur die Eigenschaft f\u00fcr eine einzige Filter-Funktion. M\u00f6chte man mehrere Filter setzen, muss man komplexe Funktionen mit Filter-Logik implementieren. <\/p>\n<h1>Ansatz<\/h1>\n<p>Durch die Erweiterung der mx:ArrayCollection wird eine Methode filterFunctions implementiert, welche mehrere Filter entgegennehmen kann. Die erweiterte BjoernsArrayCollection kann in ArrayCollection gecastet oder ggfs. (z.B. durch eine Schleife) bef\u00fcllt werden. <\/p>\n<h1>L\u00f6sung<\/h1>\n<p>Folgende Klasse erweritert die normale ArrayCollection um mehrere Filter-Funktionen:<\/p>\n<pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\r\npackage components\r\n{\r\n  import mx.collections.ArrayCollection;\r\n \r\n  public class BjoernsArrayCollection extends ArrayCollection\r\n  {\r\n      private var _filterFunctions:Array;\r\n \r\n      public function BjoernsArrayCollection( source:Array = null )\r\n      {\r\n         super(source);\r\n      }\r\n\t\r\n       public function set filterFunctions( filtersArray:Array ):void\r\n       {\r\n         _filterFunctions = filtersArray;\r\n         this.filterFunction = complexFilter;\r\n        }\r\n\t\t\r\n       public function get filterFunctions():Array\r\n       {\r\n         return _filterFunctions;\r\n       }\r\n \r\n       protected function complexFilter( item:Object ):Boolean\r\n       {\r\n         var filterFlag:Boolean = true;\r\n         var filter:Function;\r\n\r\n         for each(filter in filterFunctions)\r\n         {\r\n            filterFlag = filter( item );\r\n            if( !filterFlag ) break;\r\n         }\r\n         return filterFlag;\r\n      }\r\n    }\r\n}\r\n<\/pre>\n<p>Der Filterfunktionen werden so deklariert:<\/p>\n<pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\r\n\/\/ Result-Methode von Service liefert eine mx:ArrayCollection, die \r\n\/\/ anhand mehrerer Kriterien gefiltert wird.\r\npublic function getResetableOrganizationsHandler(event:ResultEvent):void\r\n{\r\n   \/\/ Instanzieren des neuen Objektes\r\n   resetableorgas = new BjoernsArrayCollection();\r\n\r\n   \/\/ Deklaration der Filter \r\n   resetableorgas.filterFunctions = \r\n   &#x5B;\r\n       filterByProductGroup,\r\n       filterByCompcode,\r\n       filterBySalesdiv,\r\n       filterByMarket\r\n   ];\t\r\n\t\t\r\n    \/\/ Umsortierung in BjoernsArrayCollection\r\n    resetableorgas.removeAll();\r\n\t\t\t\r\n    for each(var item:ResetableOrganizationsVO in event.result)\r\n    {\r\n       resetableorgas.addItem(item);\t\t\t\t\r\n    }\r\n    \r\n     resetableorgas.refresh();\t\r\n}\r\n<\/pre>\n<p>Der Aufbau der Filter-Funktion:<\/p>\n<pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\r\n...\r\n\/\/ R\u00fcckgabe ist true wenn der Vergleich des Eingegebenen (txtCompcode.text) \r\n\/\/ mit einem Element der ArrayCollection (item.compcode) passt\r\nprivate function filterByCompcode( item:Object ):Boolean\r\n{\r\n   if( String(item.compcode).indexOf(txtCompcode.text)&gt;-1 )return true;\r\n   return false;\r\n}\r\n...\r\n<\/pre>\n<p>Ggfs. (z.B. in einem mx:TextInput) die Refresh-Methode aufrufen:<\/p>\n<pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\r\n     &lt;mx:TextInput change=&quot;{resetableorgas.refresh()}&quot; id=&quot;txtCompcode&quot; width=&quot;100%&quot;\/&gt;\r\n<\/pre>\n<iframe src=\"http:\/\/www.facebook.com\/plugins\/like.php?href=https%3A%2F%2Fwww.capri-soft.de%2Fblog%2F%3Fp%3D497&amp;layout=standard&amp;show_faces=true&amp;width=450&amp;action=like&amp;colorscheme=light\" scrolling=\"no\" frameborder=\"0\" allowTransparency=\"true\" style=\"border:none; overflow:hidden; width:450px;margin-top:5px;\"><\/iframe>","protected":false},"excerpt":{"rendered":"<p>Aufgabenstellung Es wird eine Datenstruktur ben\u00f6tigt, die mehrere FilterFunctions unterst\u00fctzt und mit der mx:ArrayCollection kompatibel ist. Problem mx:ArrayCollection besitzt nur die Eigenschaft f\u00fcr eine einzige Filter-Funktion. M\u00f6chte man mehrere Filter setzen, muss man komplexe Funktionen mit Filter-Logik implementieren. Ansatz Durch die Erweiterung der mx:ArrayCollection wird eine Methode filterFunctions implementiert, welche mehrere Filter entgegennehmen kann. Die &hellip; <a href=\"https:\/\/www.capri-soft.de\/blog\/?p=497\" class=\"more-link\"><span class=\"screen-reader-text\">Adobe Flex 3: Multi-FilterFunction auf mx:ArrayCollection<\/span> weiterlesen <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":false,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"font":"","enabled":false},"version":2}},"categories":[5],"tags":[],"class_list":["post-497","post","type-post","status-publish","format-standard","hentry","category-adobe-flex"],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"jetpack_shortlink":"https:\/\/wp.me\/p4yGeN-81","jetpack_likes_enabled":true,"jetpack-related-posts":[],"_links":{"self":[{"href":"https:\/\/www.capri-soft.de\/blog\/index.php?rest_route=\/wp\/v2\/posts\/497","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.capri-soft.de\/blog\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.capri-soft.de\/blog\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.capri-soft.de\/blog\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.capri-soft.de\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=497"}],"version-history":[{"count":3,"href":"https:\/\/www.capri-soft.de\/blog\/index.php?rest_route=\/wp\/v2\/posts\/497\/revisions"}],"predecessor-version":[{"id":500,"href":"https:\/\/www.capri-soft.de\/blog\/index.php?rest_route=\/wp\/v2\/posts\/497\/revisions\/500"}],"wp:attachment":[{"href":"https:\/\/www.capri-soft.de\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=497"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.capri-soft.de\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=497"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.capri-soft.de\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=497"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}