強強聯合之jquery操作angularjs對象


jquery是一個非常強大的js框架,angularjs是一個非常牛的前端mvc框架。雖然用其中的任何一個框架在項目中夠用了,但是有時候這兩個框架需要混合着用,雖然不推薦。但有時候混合用時,卻非常方便,不要考慮那么多,只要能實現功能,何樂而不為?

  最近做的一個產品,前端用angularjs,但表格框架用的卻是jquery.datatables.js,當然其中少不了碰到jquery與angularjs交互問題。由於公司保密,我就不用真實項目演示了,寫個小demo吧,當然真實的項目要復雜得多。

 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>

代碼

效果

點了兩次,這三個值都加到2了,貌似沒什么問題。

真沒問題嗎?請看

視圖上是2,model上還是0,沒有實現同步,怎么辦?

那么問題又來了,jquery和angularjs哪家強呢?

改下代碼

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 });

再看看

點了兩次,中間那個變成了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不同步。

如果覺得對你有幫助,請點個贊,謝謝!

不足與錯誤之處,敬請批評指正!

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM