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 相关文章推荐
JavaScript面向对象程序设计三 原型模式(上)
Dec 21 Javascript
jQuery对html元素取值与赋值的方法
Nov 20 Javascript
简单js代码实现selece二级联动(推荐)
Feb 18 Javascript
jquery操作对象数组元素方法详解
Nov 26 Javascript
jQuery添加删除DOM元素方法详解
Jan 18 Javascript
js实现1,2,3,5数字按照概率生成
Sep 12 Javascript
react-native组件中NavigatorIOS和ListView结合使用的方法
Sep 30 Javascript
vue实现模态框的通用写法推荐
Feb 26 Javascript
vue的for循环使用方法
Feb 12 Javascript
13 个npm 快速开发技巧(推荐)
Jul 04 Javascript
借助云开发实现小程序短信验证码的发送
Jan 06 Javascript
vue+element-ui JYAdmin后台管理系统模板解析
Jul 28 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开发中四种查询返回结果分析
2011/01/02 PHP
PHP unlink与rmdir删除目录及目录下所有文件实例代码
2018/02/07 PHP
PHP chop()函数讲解
2019/02/11 PHP
thinkphp5.1框架容器与依赖注入实例分析
2019/07/23 PHP
RR vs IO BO3 第一场2.13
2021/03/10 DOTA
javascript语句中的CDATA标签的意义
2007/05/09 Javascript
ext读取两种结构的xml的代码
2008/11/05 Javascript
jQuery中校验时间格式的正则表达式小结
2013/09/22 Javascript
node.js中的path.resolve方法使用说明
2014/12/08 Javascript
js实现绿白相间竖向网页百叶窗动画切换效果
2015/03/02 Javascript
ES6新特征数字、数组、字符串
2016/10/01 Javascript
关于 jQuery Easyui异步加载tree的问题解析
2016/12/06 Javascript
JavaScript实现倒计时跳转页面功能【实用】
2016/12/13 Javascript
Vue监听数据对象变化源码
2017/03/09 Javascript
bootstrap select2插件用ajax来获取和显示数据的实例
2018/08/09 Javascript
Vue登录注册并保持登录状态的方法
2018/08/17 Javascript
100行代码实现一个vue分页组功能
2018/11/06 Javascript
使用webpack搭建vue项目实现脚手架功能
2019/03/15 Javascript
JS中==、===你分清楚了吗
2020/03/04 Javascript
详解JavaScript之Array.reduce源码解读
2020/11/01 Javascript
vue使用过滤器格式化日期
2021/01/20 Vue.js
详解Python的单元测试
2015/04/28 Python
在Python中操作列表之List.pop()方法的使用
2015/05/21 Python
pygame 精灵的行走及二段跳的实现方法(必看篇)
2017/07/10 Python
Python 操作文件的基本方法总结
2017/08/10 Python
使用python生成目录树
2018/03/29 Python
TensorFlow 模型载入方法汇总(小结)
2018/06/19 Python
Django添加KindEditor富文本编辑器的使用
2018/10/24 Python
CentOS 7 安装python3.7.1的方法及注意事项
2018/11/01 Python
Numpy中ndim、shape、dtype、astype的用法详解
2020/06/14 Python
Python如何读取、写入CSV数据
2020/07/28 Python
利于python脚本编写可视化nmap和masscan的方法
2020/12/29 Python
综合素质评价个性发展自我评价
2015/03/06 职场文书
2019优秀干部竞聘演讲稿范文!
2019/07/02 职场文书
如何让vue长列表快速加载
2021/03/29 Vue.js
vue+iview实现手机号分段输入框
2022/03/25 Vue.js