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新闻滚动插件 jquery.roller.js
Jun 27 Javascript
Javascript类定义语法,私有成员、受保护成员、静态成员等介绍
Dec 08 Javascript
jquery 滚动条事件简单实例
Jul 12 Javascript
浅析JavaScript基本类型与引用类型
May 28 Javascript
jQuery使用addClass()方法给元素添加多个class样式
Mar 26 Javascript
js添加绑定事件的方法
May 15 Javascript
JS中的==运算: [''] == false —&gt;true
Jul 24 Javascript
js实现瀑布流效果(自动生成新的内容)
Mar 16 Javascript
jQuery Validate 校验多个相同name的方法
May 18 jQuery
Node.js利用js-xlsx处理Excel文件的方法详解
Jul 05 Javascript
jquery ajaxfileupload异步上传插件
Nov 21 jQuery
vue 自定义组件的写法与用法详解
Mar 04 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
php5 and xml示例
2006/11/22 PHP
利用curl 多线程 模拟 并发的详解
2013/06/14 PHP
ThinkPHP缓存方法S()概述
2014/06/13 PHP
PHP大文件分块上传功能实例详解
2019/07/22 PHP
javascript 必知必会之closure
2009/09/21 Javascript
判断JS对象是否拥有某种属性的两种方式
2013/12/02 Javascript
JavaScript表单通过正则表达式验证电话号码
2014/03/14 Javascript
在jquery中的ajax方法怎样通过JSONP进行远程调用
2014/04/04 Javascript
自定义百度分享的分享按钮
2015/03/18 Javascript
jQuery scrollFix滚动定位插件
2015/04/01 Javascript
JQuery实现左右滚动菜单特效
2015/09/28 Javascript
js实现二级菜单渐隐显示
2015/11/03 Javascript
jQuery简单验证上传文件大小及类型的方法
2016/06/02 Javascript
基于JS实现导航条之调用网页助手小精灵的方法
2016/06/17 Javascript
JS封装通过className获取元素的函数示例
2016/12/20 Javascript
微信小程序左滑删除效果的实现代码
2017/02/20 Javascript
原生JS改变透明度实现轮播效果
2017/03/24 Javascript
Vue-cli创建项目从单页面到多页面的方法
2017/09/20 Javascript
把vue-router和express项目部署到服务器的方法
2018/02/21 Javascript
修改layui的后台模板的左侧导航栏可以伸缩的方法
2019/09/10 Javascript
vue实现虚拟列表功能的代码
2020/07/28 Javascript
Python生成随机数的方法
2014/01/14 Python
Windows下为Python安装Matplotlib模块
2015/11/06 Python
利用Python查看目录中的文件示例详解
2017/08/28 Python
pandas将numpy数组写入到csv的实例
2018/07/04 Python
python网络编程之五子棋游戏
2020/05/14 Python
Python脚本破解压缩文件口令实例教程(zipfile)
2020/06/14 Python
pandas数据分组groupby()和统计函数agg()的使用
2021/03/04 Python
利用css3径向渐变做一张优惠券的示例
2018/03/22 HTML / CSS
HTML5 用动画的表现形式装载图像
2016/03/08 HTML / CSS
俄罗斯披萨、寿司和面食送货到家服务:2 Берега
2019/12/15 全球购物
大学生就业协议书范本(适用于公司企业)
2014/10/07 职场文书
2015年社区国庆节活动总结
2015/07/30 职场文书
子女赡养老人协议书
2016/03/23 职场文书
《哪吒之魔童降世》观后感:世上哪有随随便便的成功
2019/11/08 职场文书
golang中切片copy复制和等号复制的区别介绍
2021/04/27 Golang