<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <div> <input type="text" name="" id="txt-title"/> <button id="btn-submit">submit</button> </div> <div> <ul id="ul-list"></ul> </div> <script src="https://code.jquery.com/jquery-3.4.1.min.js"></script> <script> var $txtTitle = $('#txt-title'); var $ulList = $('#ul-list'); var $btnSubmit = $('#btn-submit'); $btnSubmit.click(function(){ var title = $txtTitle.val(); var $li = $('<li>'+ title +'</li>') $ulList.append($li); $txtTitle.val(''); }) </script> </body> </html>
這是jquery實現一個todolist的過程,通過點選事件,初始化一個新的li標籤,append進去的。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> </head> <body> <div id="app"> <input v-model='title'/> <button v-on:click='add'>submit</button> <ul v-for='item in list'> {{item}} </ul> </div> <script src="https://cdn.bootcss.com/vue/2.6.10/vue.min.js"></script> <script> var data = { title: '', list: [] } var vm = new Vue({ el: '#app', data: data, methods: { add: function(){ this.list.push(this.title); this.title = '' } } }) </script> </body> </html>
這是vue實現todolist的過程。不管裡面的變數還是函式都跟vue物件裡面有對應關係。在點選按鈕的時候只需要操作裡面的資料就行了。
兩者的區別:
1、資料和檢視的分離
所謂檢視就是dom,jquery的檢視在html裡面,也有在js裡面,上面的例子比如li。他把檢視和資料混在一塊了,所以jquery,資料和檢視沒有分離。混在一塊的壞處1,不符合開放封閉原則,對擴充套件開放,對修改封閉。所有這種混在一塊的,都違背了擴充套件封閉原則。
vue中找資料和dom非常方便,資料是哪塊,dom是哪塊。資料和檢視是分離的,資料就是data,vue中的列表不是空殼是有內容的。
2、以資料驅動檢視
意思是我只改資料,jquery就違背了這點,li標籤是生生append到list中。這種清空value是直接以底層到api來操作的。所以jquery中以資料驅動檢視是完全沒有的,不存在的。以資料驅動檢視是通過資料的修改,由框架自動的把檢視改了,我們不用管dom元素是怎麼樣的。jquery是干預了檢視的修改。
vue中以資料驅動檢視更明顯了,在點選按鈕的時候,只是把資料push到list,沒有操作dom,只是關心資料到變化,資料到清空也是隻關心資料到變化。
這種是不是更符合我們到開發模式,我們希望把資料模型改了就好,不需要管dom,dom的渲染其實跟業務流程關係不大。我們只需要關心資料的變化。資料和檢視的分離,問題主要是解耦(開放封閉原則)。