jquery是一個很是強大的js框架,angularjs是一個很是牛的前端mvc框架。雖然用其中的任何一個框架在項目中夠用了,可是有時候這兩個框架須要混合着用,雖然不推薦。但有時候混合用時,卻很是方便,不要考慮那麼多,只要能實現功能,何樂而不爲?javascript
最近作的一個產品,前端用angularjs,但表格框架用的倒是jquery.datatables.js,固然其中少不了碰到jquery與angularjs交互問題。因爲公司保密,我就不用真實項目演示了,寫個小demo吧,固然真實的項目要複雜得多。html
1 <!DOCTYPE html> 2 <html ng-app="ngDemo"> 3 <head> 4 <title></title> 5 <script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"></script> 6 <script src="//www.w3cschool.cc/try/angularjs/1.2.5/angular.min.js"></script> 7 <script type="text/javascript"> 8 $(function() { 9 $('#btn').on('click',function(e) { 10 $('#dv2').text(Number($('#dv2').text())+1);//jquery+angular實現 11 $('#dv3').text(Number($('#dv3').text())+1);//純jquery實現 12 }); 13 }); 14 15 var app=angular.module('ngDemo',[]); 16 app.controller('ngCtrl',['$scope',function ($scope) { 17 $scope.test1=0; 18 $scope.test2=0; 19 }]); 20 </script> 21 </head> 22 <body ng-controller="ngCtrl"> 23 test1:<div id="dv1">{{test1}}</div><!--純angular實現--> 24 test2:<div id="dv2" ng-bind="test2" ng-model="test2"></div> 25 test3:<div id="dv3">0</div> 26 <button id="btn" ng-click="test1=test1+1">click me +1</button> 27 </body> 28 </html>
代碼前端
效果java
點了兩次,這三個值都加到2了,貌似沒什麼問題。jquery
真沒問題嗎?請看angularjs
視圖上是2,model上仍是0,沒有實現同步,怎麼辦?mvc
那麼問題又來了,jquery和angularjs哪家強呢?app
改下代碼框架
1 $('#btn').on('click',function(e) {
2 var scope=angular.element('#dv2').scope();//jquery+angular實現 3 scope.test2=scope.test2+1;//直接修改test2的值 4 console.log(scope.test2); 5 $('#dv3').text(Number($('#dv3').text())+1);//純jquery實現 6 });
再看看spa
點了兩次,中間那個變成了1,其它兩個是2。
點了3次,中間那個變成了2,可是scope.test2的值倒是什麼,它怎麼老是顯示慢一拍?
再改改
$('#btn').on('click',function(e) {
var scope=angular.element('#dv2').scope();//jquery+angular實現
scope.test2=scope.test2+1;//直接修改test2的值
scope.$apply();//綁定到視圖
console.log(scope.test2);
$('#dv3').text(Number($('#dv3').text())+1);//純jquery實現
});
再看看
這下這三個都同步了。中藥好,西藥快,中本結合!jquery簡單,angularjs方便,二者結合...大功告成。
注意:scope對象必定要調用$apply(),不然會出現視圖與model不一樣步。
若是以爲對你有幫助,請點個贊,謝謝!
不足與錯誤之處,敬請批評指正!