{"id":4991,"date":"2016-04-26T10:26:12","date_gmt":"2016-04-26T02:26:12","guid":{"rendered":"https:\/\/sdeno.com\/?p=4991"},"modified":"2020-11-10T00:44:41","modified_gmt":"2020-11-09T16:44:41","slug":"%e4%bb%80%e4%b9%88%e6%98%afmvc%ef%bc%8cmvp-%e5%92%8c-mvvm","status":"publish","type":"post","link":"https:\/\/sdeno.com\/?p=4991","title":{"rendered":"\u4ec0\u4e48\u662fMVC\uff0cMVP \u548c MVVM"},"content":{"rendered":"<p>MVC\uff0cMVP \u548c MVVM\u662f\u4ec0\u4e48<\/p>\n<p style=\"color: #111111;\">MVC\u6a21\u5f0f\u7684\u610f\u601d\u662f\uff0c\u8f6f\u4ef6\u53ef\u4ee5\u5206\u6210\u4e09\u4e2a\u90e8\u5206\u3002<\/p>\n<p style=\"color: #111111;\"><a href=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m1.png\"><figure class=\"mdx-lazyload-container\" style=\"max-width:512px\"><div style=\"padding-top:68.5546875%\"><\/div><div class=\"mdx-img-loading-sp mdui-valign\"><div><div class=\"mdui-spinner\"><\/div><\/div><\/div><img width=\"512\" height=\"351\" class=\"alignnone size-full wp-image-4992 lazyload\" title=\"m1\" src=\"data:image\/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\" data-src=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m1.png\" alt=\"m1\" data-srcset=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m1.png 512w, https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m1-300x205.png 300w\" sizes=\"auto, (max-width: 512px) 100vw, 512px\"><\/figure><\/a><\/p>\n<blockquote style=\"color: #111111;\">\n<ul style=\"color: #111111;\">\n<li style=\"color: #111111;\">\u89c6\u56fe\uff08View\uff09\uff1a\u7528\u6237\u754c\u9762\uff0c\u524d\u7aef\u53c2\u4e0e\u3002<\/li>\n<li style=\"color: #111111;\">\u63a7\u5236\u5668\uff08Controller\uff09\uff1a\u4e1a\u52a1\u903b\u8f91\uff0c\u4e5f\u5c31\u662fif else\u4ee3\u7801\u5224\u65ad\uff0c\u540e\u7aef\u53c2\u4e0e<\/li>\n<li style=\"color: #111111;\">\u6a21\u578b\uff08Model\uff09\uff1a\u63d0\u4f9b\/\u4fdd\u5b58\u6570\u636e<\/li>\n<\/ul>\n<\/blockquote>\n<p style=\"color: #111111;\">\u5404\u90e8\u5206\u4e4b\u95f4\u7684\u901a\u4fe1\u65b9\u5f0f\u5982\u4e0b\u3002<\/p>\n<p style=\"color: #111111;\"><a href=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m2.png\"><figure class=\"mdx-lazyload-container\" style=\"max-width:601px\"><div style=\"padding-top:60.732113144759%\"><\/div><div class=\"mdx-img-loading-sp mdui-valign\"><div><div class=\"mdui-spinner\"><\/div><\/div><\/div><img width=\"601\" height=\"365\" class=\"alignnone size-full wp-image-4993 lazyload\" title=\"m2\" src=\"data:image\/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\" data-src=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m2.png\" alt=\"m2\" data-srcset=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m2.png 601w, https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m2-300x182.png 300w\" sizes=\"auto, (max-width: 601px) 100vw, 601px\"><\/figure><\/a><\/p>\n<blockquote style=\"color: #111111;\">\n<ol style=\"color: #111111;\" start=\"1\">\n<li style=\"color: #111111;\">View \u4f20\u9001\u6307\u4ee4\u5230 Controller<\/li>\n<li style=\"color: #111111;\">Controller \u5b8c\u6210\u4e1a\u52a1\u903b\u8f91\u540e\uff0c\u8981\u6c42 Model \u6539\u53d8\u72b6\u6001<\/li>\n<li style=\"color: #111111;\">Model \u5c06\u65b0\u7684\u6570\u636e\u53d1\u9001\u5230 View\uff0c\u7528\u6237\u5f97\u5230\u53cd\u9988<\/li>\n<\/ol>\n<\/blockquote>\n<p style=\"color: #111111;\">\u6240\u6709\u901a\u4fe1\u90fd\u662f\u5355\u5411\u7684\u3002<\/p>\n<h2 style=\"font-weight: 500; color: #000000;\">\u4e8c\u3001\u4e92\u52a8\u6a21\u5f0f<\/h2>\n<p style=\"color: #111111;\">\u63a5\u53d7\u7528\u6237\u6307\u4ee4\u65f6\uff0cMVC \u53ef\u4ee5\u5206\u6210\u4e24\u79cd\u65b9\u5f0f\u3002\u4e00\u79cd\u662f\u901a\u8fc7 View \u63a5\u53d7\u6307\u4ee4\uff0c\u4f20\u9012\u7ed9 Controller\u3002<\/p>\n<p style=\"color: #111111;\"><a href=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m3.png\"><figure class=\"mdx-lazyload-container\" style=\"max-width:583px\"><div style=\"padding-top:87.478559176672%\"><\/div><div class=\"mdx-img-loading-sp mdui-valign\"><div><div class=\"mdui-spinner\"><\/div><\/div><\/div><img width=\"583\" height=\"510\" class=\"alignnone size-full wp-image-4994 lazyload\" title=\"m3\" src=\"data:image\/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\" data-src=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m3.png\" alt=\"m3\" data-srcset=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m3.png 583w, https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m3-300x262.png 300w\" sizes=\"auto, (max-width: 583px) 100vw, 583px\"><\/figure><\/a><\/p>\n<p style=\"color: #111111;\">\u53e6\u4e00\u79cd\u662f\u76f4\u63a5\u901a\u8fc7controller\u63a5\u53d7\u6307\u4ee4\u3002<\/p>\n<p style=\"color: #111111;\"><a href=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m4.png\"><figure class=\"mdx-lazyload-container\" style=\"max-width:562px\"><div style=\"padding-top:86.476868327402%\"><\/div><div class=\"mdx-img-loading-sp mdui-valign\"><div><div class=\"mdui-spinner\"><\/div><\/div><\/div><img width=\"562\" height=\"486\" class=\"alignnone size-full wp-image-4996 lazyload\" title=\"m4\" src=\"data:image\/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\" data-src=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m4.png\" alt=\"m4\" data-srcset=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m4.png 562w, https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m4-300x259.png 300w\" sizes=\"auto, (max-width: 562px) 100vw, 562px\"><\/figure><\/a><\/p>\n<h2 style=\"font-weight: 500; color: #000000;\"><\/h2>\n<h2 style=\"font-weight: 500; color: #000000;\"><\/h2>\n<p>&nbsp;<\/p>\n<h2 style=\"font-weight: 500; color: #000000;\">\u4e09\u3001\u5b9e\u4f8b\uff1aBackbone<\/h2>\n<p style=\"color: #111111;\">\u5b9e\u9645\u9879\u76ee\u5f80\u5f80\u91c7\u7528\u66f4\u7075\u6d3b\u7684\u65b9\u5f0f\uff0c\u4ee5\u00a0<a style=\"color: #112233;\" href=\"http:\/\/documentcloud.github.com\/backbone\" target=\"_blank\" rel=\"noopener\">Backbone.js<\/a>\u00a0\u4e3a\u4f8b\u3002<\/p>\n<p style=\"color: #111111;\"><a href=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m5.png\"><figure class=\"mdx-lazyload-container\" style=\"max-width:635px\"><div style=\"padding-top:90.708661417323%\"><\/div><div class=\"mdx-img-loading-sp mdui-valign\"><div><div class=\"mdui-spinner\"><\/div><\/div><\/div><img width=\"635\" height=\"576\" class=\"alignnone size-full wp-image-4997 lazyload\" title=\"m5\" src=\"data:image\/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\" data-src=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m5.png\" alt=\"m5\" data-srcset=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m5.png 635w, https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m5-300x272.png 300w\" sizes=\"auto, (max-width: 635px) 100vw, 635px\"><\/figure><\/a><\/p>\n<p style=\"color: #111111;\">1. \u7528\u6237\u53ef\u4ee5\u5411 View \u53d1\u9001\u6307\u4ee4\uff08DOM \u4e8b\u4ef6\uff09\uff0c\u518d\u7531 View \u76f4\u63a5\u8981\u6c42 Model \u6539\u53d8\u72b6\u6001\u3002<\/p>\n<p style=\"color: #111111;\">2. \u7528\u6237\u4e5f\u53ef\u4ee5\u76f4\u63a5\u5411 Controller \u53d1\u9001\u6307\u4ee4\uff08\u6539\u53d8 URL \u89e6\u53d1 hashChange \u4e8b\u4ef6\uff09\uff0c\u518d\u7531 Controller \u53d1\u9001\u7ed9 View\u3002<\/p>\n<p style=\"color: #111111;\">3. Controller \u975e\u5e38\u8584\uff0c\u53ea\u8d77\u5230\u8def\u7531\u7684\u4f5c\u7528\uff0c\u800c View \u975e\u5e38\u539a\uff0c\u4e1a\u52a1\u903b\u8f91\u90fd\u90e8\u7f72\u5728 View\u3002\u6240\u4ee5\uff0cBackbone \u7d22\u6027\u53d6\u6d88\u4e86 Controller\uff0c\u53ea\u4fdd\u7559\u4e00\u4e2a Router\uff08\u8def\u7531\u5668\uff09 \u3002<\/p>\n<h2 style=\"font-weight: 500; color: #000000;\"><\/h2>\n<h2 style=\"font-weight: 500; color: #000000;\"><\/h2>\n<p>&nbsp;<\/p>\n<h2 style=\"font-weight: 500; color: #000000;\">\u56db\u3001MVP<\/h2>\n<p style=\"color: #111111;\">MVP \u6a21\u5f0f\u5c06 Controller \u6539\u540d\u4e3a Presenter\uff0c\u540c\u65f6\u6539\u53d8\u4e86\u901a\u4fe1\u65b9\u5411\u3002<\/p>\n<p style=\"color: #111111;\"><a href=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m6.png\"><figure class=\"mdx-lazyload-container\" style=\"max-width:537px\"><div style=\"padding-top:60.148975791434%\"><\/div><div class=\"mdx-img-loading-sp mdui-valign\"><div><div class=\"mdui-spinner\"><\/div><\/div><\/div><img width=\"537\" height=\"323\" class=\"alignnone size-full wp-image-4998 lazyload\" title=\"m6\" src=\"data:image\/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\" data-src=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m6.png\" alt=\"m6\" data-srcset=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m6.png 537w, https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m6-300x180.png 300w\" sizes=\"auto, (max-width: 537px) 100vw, 537px\"><\/figure><\/a><\/p>\n<p style=\"color: #111111;\">1. \u5404\u90e8\u5206\u4e4b\u95f4\u7684\u901a\u4fe1\uff0c\u90fd\u662f\u53cc\u5411\u7684\u3002<\/p>\n<p style=\"color: #111111;\">2. View \u4e0e Model \u4e0d\u53d1\u751f\u8054\u7cfb\uff0c\u90fd\u901a\u8fc7 Presenter \u4f20\u9012\u3002<\/p>\n<p style=\"color: #111111;\">3. View \u975e\u5e38\u8584\uff0c\u4e0d\u90e8\u7f72\u4efb\u4f55\u4e1a\u52a1\u903b\u8f91\uff0c\u79f0\u4e3a&#8221;\u88ab\u52a8\u89c6\u56fe&#8221;\uff08Passive View\uff09\uff0c\u5373\u6ca1\u6709\u4efb\u4f55\u4e3b\u52a8\u6027\uff0c\u800c Presenter\u975e\u5e38\u539a\uff0c\u6240\u6709\u903b\u8f91\u90fd\u90e8\u7f72\u5728\u90a3\u91cc\u3002<\/p>\n<h2 style=\"font-weight: 500; color: #000000;\"><\/h2>\n<h2 style=\"font-weight: 500; color: #000000;\"><\/h2>\n<p>&nbsp;<\/p>\n<h2 style=\"font-weight: 500; color: #000000;\">\u4e94\u3001MVVM<\/h2>\n<p style=\"color: #111111;\">\n<p style=\"color: #111111;\"><a href=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m71.png\"><figure class=\"mdx-lazyload-container\" style=\"max-width:549px\"><div style=\"padding-top:72.131147540984%\"><\/div><div class=\"mdx-img-loading-sp mdui-valign\"><div><div class=\"mdui-spinner\"><\/div><\/div><\/div><img width=\"549\" height=\"396\" class=\"alignnone size-full wp-image-5000 lazyload\" title=\"m7\" src=\"data:image\/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\" data-src=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m71.png\" alt=\"m7\" data-srcset=\"https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m71.png 549w, https:\/\/sdeno.com\/wp-content\/uploads\/2016\/04\/m71-300x216.png 300w\" sizes=\"auto, (max-width: 549px) 100vw, 549px\"><\/figure><\/a><\/p>\n<p>Model\u548cView\u5e76\u65e0\u76f4\u63a5\u5173\u8054\uff0c\u800c\u662f\u901a\u8fc7ViewModel\u6765\u8fdb\u884c\u8054\u7cfb\u7684\uff0cModel\u548cViewModel\u4e4b\u95f4\u6709\u7740\u53cc\u5411\u6570\u636e\u7ed1\u5b9a\u7684\u8054\u7cfb\u3002\u56e0\u6b64\u5f53Model\u4e2d\u7684\u6570\u636e\u6539\u53d8\u65f6\u4f1a\u89e6\u53d1View\u5c42\u7684\u5237\u65b0\uff0cView\u4e2d\u7531\u4e8e\u7528\u6237\u4ea4\u4e92\u64cd\u4f5c\u800c\u6539\u53d8\u7684\u6570\u636e\u4e5f\u4f1a\u5728Model\u4e2d\u540c\u6b65\u3002<\/p>\n<p>\u7b80\u5355\u7684\u8bf4\uff0cViewModel\u5c31\u662fView\u4e0eModel\u7684\u8fde\u63a5\u5668\uff0cView\u4e0eModel\u901a\u8fc7ViewModel\u5b9e\u73b0\u53cc\u5411\u7ed1\u5b9a\u3002<\/p>\n<p>\u8457\u4f5c\u6743\u5f52\u4f5c\u8005\u6240\u6709\u3002\u5546\u4e1a\u8f6c\u8f7d\u8bf7\u8054\u7cfb\u4f5c\u8005\u83b7\u5f97\u6388\u6743\uff0c\u975e\u5546\u4e1a\u8f6c\u8f7d\u8bf7\u6ce8\u660e\u51fa\u5904\u3002<\/p>\n<p style=\"color: #111111;\"><a href=\"http:\/\/www.ruanyifeng.com\/blog\/2015\/02\/mvcmvp_mvvm.html\" target=\"_blank\" rel=\"noopener\">http:\/\/www.ruanyifeng.com\/blog\/2015\/02\/mvcmvp_mvvm.html<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>MVC\uff0cMVP \u548c MVVM\u662f\u4ec0\u4e48 MVC\u6a21\u5f0f\u7684\u610f\u601d\u662f\uff0c\u8f6f\u4ef6\u53ef\u4ee5\u5206\u6210\u4e09\u4e2a\u90e8\u5206\u3002 \u89c6\u56fe\uff08View\uff09\uff1a\u7528\u6237\u754c\u9762\uff0c\u524d [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[11],"tags":[],"class_list":["post-4991","post","type-post","status-publish","format-standard","hentry","category-11"],"_links":{"self":[{"href":"https:\/\/sdeno.com\/index.php?rest_route=\/wp\/v2\/posts\/4991","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/sdeno.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/sdeno.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/sdeno.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/sdeno.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=4991"}],"version-history":[{"count":0,"href":"https:\/\/sdeno.com\/index.php?rest_route=\/wp\/v2\/posts\/4991\/revisions"}],"wp:attachment":[{"href":"https:\/\/sdeno.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=4991"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/sdeno.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=4991"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/sdeno.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=4991"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}