{"id":1504,"date":"2006-11-23T17:55:30","date_gmt":"2006-11-23T09:55:30","guid":{"rendered":"http:\/\/ihower.idv.tw\/blog\/archives\/1504"},"modified":"2007-04-03T03:22:11","modified_gmt":"2007-04-02T19:22:11","slug":"ajax-in-action","status":"publish","type":"post","link":"https:\/\/ihower.tw\/blog\/1504-ajax-in-action","title":{"rendered":"Ajax in Action"},"content":{"rendered":"<p><a href=\"http:\/\/www.gotop.com.tw\/waweb2004\/home\/home.aspx?pg=HM010X&amp;bn=AXP011800\"><img decoding=\"async\" src=\"http:\/\/images.amazon.com\/images\/P\/1932394613.01._SCMZZZZZZZ_V59003887_.jpg\" \/><\/a>\u00a0<\/p>\n<p>\u8edf\u9ad4\u8a2d\u8a08\u5c64\u6b21\u7684Ajax\u66f8\uff0c\u5f88\u8a8d\u771f\u7684\u601d\u8003 Single Page Application\u3002\u524d\u4e09\u7ae0\u5f15\u5165Design Patterns\u3001\u91cd\u69cb\u7684\u6982\u5ff5\u5230Javascript\uff0c\u5c07 Web Page\u63d0\u5347\u5230\u61c9\u7528\u7a0b\u5f0f\u7684\u5c64\u6b21\u3002\u56db\u4e94\u7ae0\u5f88\u7cbe\u91c7\u5730\u5206\u6790\u67b6\u69cb\uff0c\u5305\u62ec\u4e0d\u540c\u5c64\u6b21\u7684MVC\u89c0\u9ede\uff0c\u4ee5\u53ca\u5404\u7a2e\u6846\u67b6\u7684\u5927\u5c40\u89c0\u8ddf\u5206\u985e\uff0c\u5176\u4e2d\u95dc\u65bcAjax\u5982\u4f55\u4ea4\u63db\u8cc7\u6599\u63d0\u4f9b\u4e86\u5f88\u597d\u7684\u601d\u8003\uff0c\u4ee5\u4e0b\u662f\u6211\u7684\u7b46\u8a18(Rails\u662f\u6211\u52a0\u7684\uff0c\u66f8\u4e0a\u6c92\u6709):<\/p>\n<p><strong>\u5167\u5bb9\u4e2d\u5fc3\u7684\u4e92\u52d5 (content)<\/strong><\/p>\n<ul>\n<li>Server \u50b3\u56de HTML \u7247\u6bb5\uff0cClient \u5728\u7279\u5b9a\u4f4d\u7f6e\u66f4\u65b0\u986f\u793a\u3002<\/li>\n<li>\u7c21\u55ae\u76f4\u89ba\uff0c\u64b0\u5beb\u5bb9\u6613\u3002<\/li>\n<li>\u529f\u80fd\u6709\u9650\uff0c\u756b\u9762\u4e0a\u7684\u8b8a\u5316\u53ea\u9650\u65bc\u56fa\u5b9a\u77e9\u5f62\u5340\u57df\uff0c\u7121\u6cd5\u9032\u884c\u8907\u96dc\u7684DOM\u64cd\u4f5c\u3002<\/li>\n<li>Rails\u4f7f\u7528Prototype\u52a0\u4e0a\u914d\u5957\u7684 Ajax helper \u5373\u53ef\u9054\u6210\u3002<\/li>\n<\/ul>\n<p><strong>\u8173\u672c\u4e2d\u5fc3\u7684\u4e92\u52d5 (scripting)<\/strong><\/p>\n<ul>\n<li>Server \u50b3\u56de Javascript \u7247\u6bb5\uff0cClient \u76f4\u63a5\u57f7\u884c\u3002<\/li>\n<li>\u529f\u80fd\u5f48\u6027\u5927\uff0c\u53ef\u81ea\u7531\u64cd\u4f5cDOM\uff0c\u591a\u8655\u66f4\u65b0\u3002<\/li>\n<li>Rails \u652f\u63f4\u5728 Remote Javascript Template (RJS)\uff0c\u4f7f\u7528Ruby\u8a9e\u6cd5\u64b0\u5bebJavascript\uff0c\u50b3\u7d66Client\u57f7\u884c\uff0c\u6e1b\u5c11\u64b0\u5bebraw Javascript\u3002<\/li>\n<\/ul>\n<p><strong>\u8cc7\u6599\u4e2d\u5fc3\u7684\u4e92\u52d5 (data)<\/strong><\/p>\n<ul>\n<li>Server \u50b3\u56de XML \u6216 JSON \u8cc7\u6599\uff0cClient \u7684 Javascript \u89e3\u6790\u8655\u7406(\u6216\u4f7f\u7528XSLT)\u3002<\/li>\n<li>XML\u7684\u89e3\u6790\u8f03\u9ebb\u7169\uff0c\u73fe\u5728\u6d41\u884c\u7528JSON(JavaScript Object Notation)\u3002<\/li>\n<li>\u4e0a\u8ff0\u5169\u7a2e\u67b6\u69cb\u8207Client\u76f8\u4f9d\uff0c\u4f46\u8cc7\u6599\u4e2d\u5fc3\u5373Web Service(REST)\u67b6\u69cb\uff0c\u5177\u53ef\u91cd\u8907\u4f7f\u7528\u6027(\u53ef\u4f9b\u5225\u7684\u524d\u7aef\u4f7f\u7528)\u3002<\/li>\n<li>Rails\u652f\u63f4 XML Template\u8ddfJSON\u3002<\/li>\n<li>\u56e0\u70ba\u5256\u6790\u8cc7\u6599\u7684\u8ca0\u64d4\u5b8c\u5168\u653e\u5728 Client \u7aef\uff0c\u6240\u4ee5 Client \u7aef\u7684Javascript\u7a0b\u5f0f\u6216XSLT\u5de5\u7a0b\u8f03\u5927\u3002<\/li>\n<\/ul>\n<p>\u7b2c\u516d\u7ae0 \u4f7f\u7528\u8005\u9ad4\u9a57 \u5be6\u4f5c\u4e86\u4e00\u500b\u901a\u77e5\u6846\u67b6\uff0c\u7b2c\u4e03\u7ae0\u8b1b\u5b89\u5168\u6027\uff0c\u7b2c\u516b\u7ae0\u8b1b\u6548\u80fd\u53ca\u8a18\u61b6\u9ad4\u6d29\u6f0f(memory leak)\u554f\u984c\u3002\u5269\u4e0b\u5f8c\u534a\u672c\u5247\u662f\u4e00\u7ae0\u4e00\u6848\u4f8b\u3002<\/p>\n<p>\u53e6\u4e00\u7bc7\u66f8\u8a55 : <a href=\"http:\/\/blogs.relevancellc.com\/articles\/2006\/04\/21\/relevance-review-5-ajax-in-action\">Relevance Review #5: Ajax in Action<\/a><\/p>\n<p>\u8a3b:\u00a0\u4e4b\u524d\u5beb\u7684\u00a0<a href=\"http:\/\/ihower.idv.tw\/blog\/archives\/1246\">ajax \u50b3\u9001\u683c\u5f0f\u6bd4\u8f03<\/a>\u00a0: XML, HTML, or JSON?<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u00a0 \u8edf\u9ad4\u8a2d\u8a08\u5c64\u6b21\u7684Ajax\u66f8\uff0c\u5f88\u8a8d\u771f\u7684\u601d\u8003 Single Page Application\u3002\u524d\u4e09\u7ae0\u5f15\u5165Desi &hellip; <\/p>\n<p class=\"link-more\"><a href=\"https:\/\/ihower.tw\/blog\/1504-ajax-in-action\" class=\"more-link\">\u95b1\u8b80\u5168\u6587<span class=\"screen-reader-text\">\u3008Ajax in Action\u3009<\/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":[9,33,5,28,4],"tags":[],"class_list":["post-1504","post","type-post","status-publish","format-standard","hentry","category-books","category-javascript","category-programming","category-rest","category-web-design","entry"],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_shortlink":"https:\/\/wp.me\/p1q6tG-og","jetpack_sharing_enabled":true,"jetpack_likes_enabled":true,"_links":{"self":[{"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/posts\/1504","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/comments?post=1504"}],"version-history":[{"count":0,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/posts\/1504\/revisions"}],"wp:attachment":[{"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/media?parent=1504"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/categories?post=1504"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/ihower.tw\/blog\/wp-json\/wp\/v2\/tags?post=1504"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}