强强联合之jquery操做angularjs对象

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不一样步。

若是以为对你有帮助,请点个赞,谢谢!

不足与错误之处,敬请批评指正!

相关文章
相关标签/搜索