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 相关文章推荐
showModelessDialog()使用详解
Sep 07 Javascript
js跨域和ajax 跨域问题的实现思路
Sep 05 Javascript
IE无法设置短域名下Cookie
Sep 23 Javascript
JavaScript访问样式表代码
Oct 15 Javascript
javaScript年份下拉列表框内容为当前年份及前后50年
May 28 Javascript
扩展bootstrap的modal模态框-动态添加modal框-弹出多个modal框
Feb 21 Javascript
详解vuelidate 对于vueJs2.0的验证解决方案
Mar 09 Javascript
微信小程序调用PHP后台接口 解析纯html文本
Jun 13 Javascript
vue-cli开发环境实现跨域请求的方法
Apr 07 Javascript
详解js中let与var声明变量的区别
Apr 05 Javascript
vue mvvm数据响应实现
Nov 11 Javascript
深入理解javascript中的this
Feb 08 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
linux php mysql数据库备份实现代码
2009/03/10 PHP
PHP中iconv函数转码时截断字符问题的解决方法
2015/01/21 PHP
php版微信公众平台实现预约提交后发送email的方法
2016/09/26 PHP
教您去掉ie网页加载进度条的方法
2010/12/09 Javascript
解析Jquery取得iframe中元素的几种方法
2013/07/04 Javascript
setTimeout自动触发一个js的方法
2014/01/15 Javascript
JavaScript调用客户端Java程序的方法
2015/07/27 Javascript
javascript实现标签切换代码示例
2016/05/22 Javascript
Vue常用指令V-model用法
2017/03/08 Javascript
深入理解ES6的迭代器与生成器
2017/08/19 Javascript
在knockoutjs 上自己实现的flux(实例讲解)
2017/12/18 Javascript
AngularJS实时获取并显示密码的方法
2018/02/06 Javascript
node.js制作一个简单的登录拦截器
2020/02/10 Javascript
Vue中点击active并第一个默认选中功能的实现
2020/02/24 Javascript
Python复制目录结构脚本代码分享
2015/03/06 Python
Django中login_required装饰器的深入介绍
2017/11/24 Python
Pandas:DataFrame对象的基础操作方法
2018/06/07 Python
flask session组件的使用示例
2018/12/25 Python
python读取图片任意范围区域
2019/01/23 Python
Python selenium根据class定位页面元素的方法
2019/02/26 Python
python模块之subprocess模块级方法的使用
2019/03/26 Python
使用python实现画AR模型时序图
2019/11/20 Python
解决Python在导入文件时的FileNotFoundError问题
2020/04/10 Python
使用Keras建立模型并训练等一系列操作方式
2020/07/02 Python
Clarria化妆品官方网站:购买天然和有机化妆品系列
2018/04/08 全球购物
Daisy London官网:英国最大的首饰集团IBB旗下
2019/02/28 全球购物
Nº21官方在线商店:numeroventuno.com
2019/09/26 全球购物
eharmony澳大利亚:网上约会服务
2020/02/29 全球购物
麦当劳印度网上订餐:McDelivery
2020/03/16 全球购物
医学专业五年以上个人求职信
2013/12/03 职场文书
班主任新年寄语
2014/04/04 职场文书
法学自荐信
2014/06/20 职场文书
2015年度酒店客房部工作总结
2015/05/25 职场文书
教师研修随笔感言
2015/11/18 职场文书
大学生奖学金获奖感言(范文)
2019/08/15 职场文书
教你使用Jenkins集成Harbor自动发布镜像
2022/04/03 Servers