jquery操作angularjs对象_AngularJS
程序员文章站
2022-05-15 21:55:58
...
jquery是一个非常强大的js框架,angularjs是一个非常牛的前端mvc框架。虽然用其中的任何一个框架在项目中够用了,但是有时候这两个框架需要混合着用,虽然不推荐。但有时候混合用时,却非常方便,不要考虑那么多,只要能实现功能,何乐而不为?
最近做的一个产品,前端用angularjs,但表格框架用的却是jquery.datatables.js,当然其中少不了碰到jquery与angularjs交互问题。由于公司保密,我就不用真实项目演示了,写个小demo吧,当然真实的项目要复杂得多。
test1: {{test1}}test2: test3:
代码
效果
点了两次,这三个值都加到2了,貌似没什么问题。
真没问题吗?请看
视图上是2,model上还是0,没有实现同步,怎么办?
那么问题又来了,jquery和angularjs哪家强呢?
改下代码
$('#btn').on('click',function(e) { var scope=angular.element('#dv2').scope();//jquery+angular实现 scope.test2=scope.test2+1;//直接修改test2的值 console.log(scope.test2); $('#dv3').text(Number($('#dv3').text())+1);//纯jquery实现 });
再看看
点了两次,中间那个变成了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不同步。
以上所述就是本文的全部内容了,希望大家能够喜欢。
上一篇: 关于三列布局的10篇文章推荐
下一篇: 在微信小程序中如何使用三级联动选择器
推荐阅读
-
AngularJS实现与Java Web服务器交互操作示例【附demo源码下载】
-
AngularJS中的DOM操作用法分析
-
JQuery扩展对象方法操作示例
-
jQuery实现简单复制json对象和json对象集合操作示例
-
ASP.NET MVC中jQuery与angularjs混合应用传参并绑定数据
-
AngularJS入门教程之与服务器(Ajax)交互操作示例【附完整demo源码下载】
-
关于angularjs异步操作后台请求时,用$q.all排列先后顺序的问题
-
【转载】使用Jquery操作Cookie对象
-
angularjs-jqLite,在angularjs中使用jquery
-
前端笔记知识点整合之jQuery(一)加载函数的区别&对象&操作HTML/CSS&动画&选择器