全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

AngularJS1.X学习笔记2-数据绑定详解

上一篇从整体上认识了Angular,从现在开始更加深入的学习Angular的特性。本次学习的是数据绑定。应该所有的MVC框架都会用到数据绑定,比如我所知道的ThinkPHP、struts等,只有实现了数据绑定才能将模型层和视图层分离,实现MVC。Angular的数据绑定比较特别,它支持双向数据绑定。

1、ng-bind

<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
 <meta charset="UTF-8">
 <title>databinding1</title>
</head>
<body>
 <h1 ng-controller='dataCtrl' ng-bind='data'>
  
 </h1>

 <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
 <script type="text/javascript">
  angular.module('myApp',[])
  .controller('dataCtrl',function($scope){
   $scope.data = "你好啊!";
  })
 </script>
</body>
</html>

ng-bind实现了一个简单单向绑定。

2、{{}}

类似ng-bind,用的比较多。

<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
 <meta charset="UTF-8">
 <title>databinding1</title>
</head>
<body>
 <h1 ng-controller='dataCtrl'>
  {{data}}
 </h1>

 <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
 <script type="text/javascript">
  angular.module('myApp',[])
  .controller('dataCtrl',function($scope){
   $scope.data = "你好啊!";
  })
 </script>
</body>
</html>

这种绑定的缺点是,开始加载时可能会出现类似{{data}}这样的东西。

解决方法是使用ng-bind或ng-cloak,ng-cloak应该只在有数据绑定的地方使用,否则处理中用户将看到空白。

<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
 <meta charset="UTF-8">
 <title>databinding2</title>
</head>
<body ng-cloak>
 <h1 ng-controller='dataCtrl'>
  {{data}}
 </h1>

 <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
 <script type="text/javascript">
  angular.module('myApp',[])
  .controller('dataCtrl',function($scope){
   $scope.data = "你好啊!";
  })
 </script>
</body>
</html>

我测试了一下ng-cloak,不知道为什么不行,有人知道的话请告知一下。

3、ng-bind-html

这个指令可以用html的方式处理数据,它不会将html代码解析成实体。下面对比一下ng-bind和ng-bind-html.

<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
 <meta charset="UTF-8">
 <title>databinding3</title>
</head>
<body>
 <div ng-controller='dataCtrl' ng-bind='data'>
  
 </div>

 <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
 <script type="text/javascript">
  angular.module('myApp',[])
  .controller('dataCtrl',function($scope){
   $scope.data = "<h1 style='color:red;'>你好啊</h1>";
  })
 </script>
</body>
</html>

<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
  <meta charset="UTF-8">
  <title>databinding3</title>
</head>
<body>
  <div ng-controller='dataCtrl' ng-bind-html='data'>
    
  </div>

  <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
  <script type="text/javascript">
    angular.module('myApp',[])
    .controller('dataCtrl',function($scope){
      $scope.data = "<h1 style='color:red;'>你好啊</h1>";
    })
  </script>
</body>
</html>

换成ng-bind-html时出错了

这是因为Angular默认是不信任html的,所以要这样做。


<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
 <meta charset="UTF-8">
 <title>databinding3</title>
</head>
<body>
 <div ng-controller='dataCtrl' ng-bind-html='data'>
  
 </div>

 <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
 <script type="text/javascript">
  angular.module('myApp',[])
  .controller('dataCtrl',function($scope,$sce){
   $scope.data = $sce.trustAsHtml("<h1 style='color:red;'>你好啊</h1>");
  })
 </script>
</body>
</html

这样就可以了。

4、ng-bind-template

ng-bind只接受单个数据绑定表达式,而ng-bind-template则相对灵活些。

<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
 <meta charset="UTF-8">
 <title>databinding3</title>
</head>
<body>
 <div ng-controller='dataCtrl' ng-bind-template='{{data1}}爱{{data2}} '>
  
 </div>

 <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
 <script type="text/javascript">
  angular.module('myApp',[])
  .controller('dataCtrl',function($scope,$sce){
   $scope.data1 = "我";
   $scope.data2 = "中国";
  })
 </script>
</body>
</html>
<!-- 我爱中国-->

5、ng-non-bindable

有时我们使用了{{}}但是我们并不是要绑定数据,直接用会出错,所以要像这样

<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
 <meta charset="UTF-8">
 <title>databinding1</title>
</head>
<body>
 <h1 ng-controller='dataCtrl' ng-non-bindable>
  ng中绑定数据的方法是{{data}}
 </h1>

 <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
 <script type="text/javascript">
  angular.module('myApp',[])
  .controller('dataCtrl',function($scope){
   //$scope.data = "你好啊!";
  })
 </script>
</body>
</html>

6、双向数据绑定ng-model

双向数据绑定允许元素从用户处收集数据以改变程序状态。

<!DOCTYPE html>
<html lang="en" ng-app="myApp">
<head>
 <meta charset="UTF-8">
 <title>databinding5</title>
</head>
<body>
 <div ng-controller='dataCtrl'>
  <h1>{{data}}</h1>
  <input type="text" name="data" ng-model="data">
 </div>
  
 
 <script type="text/javascript" src="../node_modules/angular/angular.min.js"></script>
 <script type="text/javascript">
  angular.module('myApp',[])
  .controller('dataCtrl',function($scope){
   $scope.data = "你好啊!";
  })
 </script>
</body>
</html>

你会发现文本框的内容和h1中的内容同步变化。

7、小结一下

与数据绑定的相关指令如下

  

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# angularjs  # 绑定数据  # angularjs的数据绑定  # 双向绑定  # 详谈AngularJs 控制器、数据绑定、作用域  # 深入浅析AngularJS中的一次性数据绑定 (bindonce)  # AngularJS框架中的双向数据绑定机制详解【减少需要重复的开发代码量】  # AngularJS入门教程之数据绑定原理详解  # AngularJS入门教程之数据绑定用法示例  # AngularJS 双向数据绑定详解简单实例  # AngularJS实践之使用NgModelController进行数据绑定  # 详解JavaScript的AngularJS框架中的作用域与数据绑定  # angularjs学习笔记之双向数据绑定  # Angularjs中数据绑定的实例详解  # 绑定  # 你好啊  # 中国  # 的是  # 实现了  # 可以用  # 我爱  # 错了  # 这样做  # 只在  # 上一篇  # 能将  # 不知道为什么  # 比较多  # 会将  # 这是因为  # 它不  # 解决方法  # 你会发现  # 不信任 


相关文章: 如何快速搭建高效香港服务器网站?  如何在七牛云存储上搭建网站并设置自定义域名?  制作表格网站有哪些,线上表格怎么弄?  如何安全更换建站之星模板并保留数据?  网站制作员失业,怎样查看自己网站的注册者?  利用JavaScript实现拖拽改变元素大小  建站之星后台密码遗忘或太弱?如何重置与强化?  定制建站流程步骤详解:一站式方案设计与开发指南  上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  早安海报制作网站推荐大全,企业早安海报怎么每天更换?  建站之星备案是否影响网站上线时间?  制作网站怎么制作,*游戏网站怎么搭建?  建站之星IIS配置教程:代码生成技巧与站点搭建指南  如何基于云服务器快速搭建网站及云盘系统?  完全自定义免费建站平台:主题模板在线生成一站式服务  建站之星如何修改网站生成路径?  北京建设网站制作公司,北京古代建筑博物馆预约官网?  如何快速生成高效建站系统源代码?  图册素材网站设计制作软件,图册的导出方式有几种?  如何选择适合PHP云建站的开源框架?  营销式网站制作方案,销售哪个网站招聘效果最好?  如何登录建站主机?访问步骤全解析  无锡制作网站公司有哪些,无锡优八网络科技有限公司介绍?  做企业网站制作流程,企业网站制作基本流程有哪些?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  制作宣传网站的软件,小红书可以宣传网站吗?  建站之星如何保障用户数据免受黑客入侵?  网站设计制作公司地址,网站建设比较好的公司都有哪些?  如何在搬瓦工VPS快速搭建网站?  微信小程序制作网站有哪些,微信小程序需要做网站吗?  如何快速登录WAP自助建站平台?  制作网站的模板软件,网站怎么建设?  如何通过云梦建站系统实现SEO快速优化?  网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?  道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?  南宁网站建设制作定制,南宁网站建设可以定制吗?  已有域名和空间如何快速搭建网站?  建站主机助手选型指南:2025年热门推荐与高效部署技巧  如何快速搭建高效WAP手机网站吸引移动用户?  如何快速打造个性化非模板自助建站?  青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?  如何在宝塔面板中创建新站点?  文字头像制作网站推荐软件,醒图能自动配文字吗?  如何在建站之星绑定自定义域名?  建站之星云端配置指南:模板选择与SEO优化一键生成  佛山企业网站制作公司有哪些,沟通100网上服务官网?  宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。