jquery操作angularjs对象


Posted in Javascript onJune 26, 2015

jquery是一个非常强大的js框架,angularjs是一个非常牛的前端mvc框架。虽然用其中的任何一个框架在项目中够用了,但是有时候这两个框架需要混合着用,虽然不推荐。但有时候混合用时,却非常方便,不要考虑那么多,只要能实现功能,何乐而不为?

最近做的一个产品,前端用angularjs,但表格框架用的却是jquery.datatables.js,当然其中少不了碰到jquery与angularjs交互问题。由于公司保密,我就不用真实项目演示了,写个小demo吧,当然真实的项目要复杂得多。

<!DOCTYPE html>
<html ng-app="ngDemo">
<head>
  <title></title>
  <script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"></script>
  <script src="//www.w3cschool.cc/try/angularjs/1.2.5/angular.min.js"></script>
  <script type="text/javascript">
  $(function() {
    $('#btn').on('click',function(e) {
      $('#dv2').text(Number($('#dv2').text())+1);//jquery+angular实现
      $('#dv3').text(Number($('#dv3').text())+1);//纯jquery实现
    });
  });
  
  var app=angular.module('ngDemo',[]);
  app.controller('ngCtrl',['$scope',function ($scope) {
    $scope.test1=0;
    $scope.test2=0;
  }]);
  </script>
</head>
<body ng-controller="ngCtrl">
test1:<div id="dv1">{{test1}}</div><!--纯angular实现-->
test2:<div id="dv2" ng-bind="test2" ng-model="test2"></div>
test3:<div id="dv3">0</div>
<button id="btn" ng-click="test1=test1+1">click me +1</button>
</body>
</html>

代码

jquery操作angularjs对象

效果

jquery操作angularjs对象

点了两次,这三个值都加到2了,貌似没什么问题。

真没问题吗?请看

jquery操作angularjs对象

视图上是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实现
    });

再看看

jquery操作angularjs对象

点了两次,中间那个变成了1,其它两个是2。

jquery操作angularjs对象

点了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对象

这下这三个都同步了。中药好,西药快,中本结合!jquery简单,angularjs方便,两者结合...大功告成。

注意:scope对象一定要调用$apply(),否则会出现视图与model不同步。

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
JQuery选择器特辑 详细小结
May 14 Javascript
JQuery获取样式中的background-color颜色值的问题
Aug 20 Javascript
javascript中的return和闭包函数浅析
Jun 06 Javascript
JavaScript中的无阻塞加载性能优化方案
Oct 10 Javascript
javascript 面向对象封装与继承
Nov 27 Javascript
AngularJs 禁止模板缓存的方法
Nov 28 Javascript
原生JS+HTML5实现跟随鼠标一起流动的粒子动画效果
May 03 Javascript
webpack4 + react 搭建多页面应用示例
Aug 03 Javascript
React Hooks的深入理解与使用
Nov 12 Javascript
JSON的parse()方法介绍
Jan 31 Javascript
只有 20 行的 JavaScript 模板引擎实例详解
May 11 Javascript
js验证账户名是否重复
May 26 Javascript
jQuery检查事件是否触发的方法
Jun 26 #Javascript
js限制input标签中只能输入中文
Jun 26 #Javascript
jQuery实现按钮只点击一次后就取消点击事件绑定的方法
Jun 26 #Javascript
浅谈JavaScript异常处理语句
Jun 26 #Javascript
javascript实现一个数值加法函数
Jun 26 #Javascript
javascript排序函数实现数字排序
Jun 26 #Javascript
javascript实现给定半径求出圆的面积
Jun 26 #Javascript
You might like
PHP中的类型提示(type hinting)功能介绍
2015/07/01 PHP
PHP实现基于文本的摩斯电码生成器
2016/01/11 PHP
php 实现银联商务H5支付的示例代码
2019/10/12 PHP
通过Unicode转义序列来加密,按你说的可以算是混淆吧
2007/05/06 Javascript
Javascript Tab 导航插件 (23个)
2009/06/11 Javascript
asp.net下利用js实现返回上一页的实现方法小集
2009/11/24 Javascript
JavaScript实现将文本框的值插入指定位置的方法
2015/08/13 Javascript
vue.js中指令Directives详解
2017/03/20 Javascript
JS获取鼠标坐标并且根据鼠标位置不同弹出不同内容
2017/06/12 Javascript
微信小程序tabBar底部导航中文注解api详解
2017/08/16 Javascript
AngularJS通过ng-Img-Crop实现头像截取的示例
2017/08/17 Javascript
jQuery实现的简单前端搜索功能示例
2017/10/28 jQuery
JS简单获取并修改input文本框内容的方法示例
2018/04/08 Javascript
4个顶级开源JavaScript图表库
2018/09/29 Javascript
Python模拟登录12306的方法
2014/12/30 Python
简单了解OpenCV是个什么东西
2017/11/10 Python
python画柱状图--不同颜色并显示数值的方法
2018/12/13 Python
python操作文件的参数整理
2019/06/11 Python
Python  Django 母版和继承解析
2019/08/09 Python
Win10 安装PyCharm2019.1.1(图文教程)
2019/09/29 Python
python GUI库图形界面开发之PyQt5窗口背景与不规则窗口实例
2020/02/25 Python
python shapely.geometry.polygon任意两个四边形的IOU计算实例
2020/04/12 Python
Python selenium自动化测试模型图解
2020/04/15 Python
python中remove函数的踩坑记录
2021/01/04 Python
实列教程 一款基于jquery和css3的响应式二级导航菜单
2014/11/13 HTML / CSS
意大利高端时尚买手店:Stefania Mode
2018/03/01 全球购物
数字漫画:comiXology
2020/06/13 全球购物
Oracle中delete,truncate和drop的区别
2016/05/05 面试题
食堂员工工作职责
2013/12/18 职场文书
会计与审计毕业生自荐信范文
2013/12/30 职场文书
信息员培训方案
2014/06/12 职场文书
人事经理岗位职责范本
2014/08/04 职场文书
社区党的群众路线教育实践活动剖析材料
2014/10/09 职场文书
行政复议决定书
2015/06/24 职场文书
pycharm2021激活码使用教程(永久激活亲测可用)
2021/03/30 Python
三星 3nm 芯片将于第二季度开始量产
2022/04/29 数码科技