强强联合之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不同步。

如果觉得对你有帮助,请点个赞,谢谢!

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

时间: 2024-12-25 20:19:57

强强联合之jquery操作angularjs对象的相关文章

使用jQuery操作DOM对象

一.jQuery操作样式 /* 单个样式 */ $("li:first").css("color","#009933"); /* 多个样式 */ $("li:eq(1)").css({"color":"#FFFF00","background":"#FFCCCC"}); /* 添加样式,引用style的.xxxxx */ $("li:eq

js/jquery 操作document对象

//获取对象 //js获取的是dom对象,jquery获取的是jquery对象 //jquery对象可以输出dom对象,索引方式输出dom对象,eq()[]方式输出dom对象; //通过id获取元素 /*var div=document.getElementById("one"); alert(div);//获取到的是一个html元素[object htmldivelement],DOM对象 var div=$("#one"); //alert(div);//获取到

JQuery操作DOM对象

1.追加节点( 儿子关系) append()     $("已有元素").append("动态添加元素");  在已有元素的内部的后面追加一个元素 appendTo()  $("动态添加元素").appendTo("已有元素");在已有元素的内部的后面追加一个元素 prepend()    $("已有元素").prepend("动态添加元素");  在已有元素的内部的前面追加一个元素 p

20180503 jq学习记录(jquery操作样式表,时间片,jq对象函数间传递)

 jquery 操作dom对象    1.1  动态添加及删除一个dom对象 添加:  var 新对象=document.createElemente("标签""); $(对象预放位置父对象).append(新对象)  //添加完成// 删除: $(新对象).remove()  //删除完成//    1.2  动态操作对象css 设置css: $(对象).css('css属性','样式值') 附加小知识:   1,关于定时器操作  var obj= setInerval(f

JQuery 操作对象的属性值

通过JQuery去操作前台对象(div,span...)的属性是很常见的事情,本文就简单的介绍几种操作情形. 1):通过属性值去获取对象 2):用JQuery去修改对象的属性值 3):获取并修改对象的Style的属性值 <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <title></title> <script src=&quo

对比jQuery和AngularJS的不同思维模

Question 假设我已经熟悉了如何使用jQuery来开发客户端应用,我现在打算使用AngularJS.请描述一下有那些思维模式方面的东西需要转变吗?下面是举出一些具体的问题,用来帮助你回答我的这个问题: 我应该以何种不同的方式来架构和设计客户端web应用?最大的不同点是什么? 我应该停止使用哪些东西:又应该开始使用哪些东西来替代? 服务端有没有什么需要考虑或者说需要约束的地方? 1.不要预先设计页面,然后再用DOM操作去修改它 在jQuery里面,你会先设计好一个页面,然后再让它变成动态的.

jquery的Deferred 对象初体验

之前阅读了阮一峰老师的jQuery的deferred对象详解一文,结合jquery手册,算是对Deferred对象有了初步的认知.今天便来分享一下我自己的一些体会. 一.deferred可以方便的添加回调 先来看下面的例子 1 var test = function(callback) { 2 setTimeout(function() { 3 console.log('我完成了'); 4 callback('我是回调') 5 }, 1000) 6 }; 7 test(function(text

jQuery操作Dom、jQuery事件机制、jQuery补充部分

jQuery操作Dom: 修改属性: //使用attr()方法 //attr(name, value) //name:要修改的属性的属性名 //value:对应的值 //attr方法,如果当前标签有要修改的属性,就会进行修改,如果没有,直接添加 例:$("a").attr("href","http://www.baidu.com"); 修改多个属性值: //attr(obj) $(“img”).attr({ “title”: ”文件名称”, “s

对比jQuery和AngularJS的不同思维模式

jQuery是dom驱动,AngularJS是数据驱动,这里有一篇文章阐述的非常好,建议看看 本文来自StackOverFlow上How do I “think in AngularJS” if I have a jQuery background?一题中得票最高的回答.该回答得票超过3000次,回答者Josh David Miller是活跃于开源社区的开发者,也是Emergenesis公司的联合创始人.该答案最初由数云架构师韩铮翻译并发布在自己的博客上,在征得Josh同意后由韩铮本人推荐给 I