前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >angularjs通过ng-change和watch两种方式实现对表单输入改变的监控

angularjs通过ng-change和watch两种方式实现对表单输入改变的监控

原创
作者头像
小小许
修改于 2018-08-31 01:43:01
修改于 2018-08-31 01:43:01
87500
代码可运行
举报
文章被收录于专栏:angularejs学习篇angularejs学习篇
运行总次数:0
代码可运行

angularjs通过ng-change和watch两种方式实现对表单输入改变的监控

直接上练习代码

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title></title>
</head>
<body ng-app="myApp" ng-controller="myContro">
    <div>
        <h1>ng-change指令</h1>
        ng-change指令,当表单输入发生改变时,会触发该事件<br />
        <div>
            姓名:<input type="text" id="name1" ng-model="user.name"
                placeholder="请输入姓名" ng-change="inputChange()" />
        </div>
        <div>
            年龄:<input type="number" ng-model="user.age"
                placeholder="请输入年龄" ng-change="inputChange()" />
        </div>
        <div>{{user.message}}</div>
    </div>
    <div>
        <h1>通过监听改变达到和ng-chang一样的效果</h1>
        <div>
            姓名:<input type="text" id="name2" ng-model="user2.name"
                placeholder="请输入姓名" />
        </div>
        <div>
            年龄:<input type="number" ng-model="user2.age"
                placeholder="请输入年龄" />
        </div>
        <div>{{user2.message}}</div>
    </div>
</body>
</html>
<script src="../JS/angular.js"></script>
<script type="text/javascript">
    var app = angular.module("myApp", []);
    app.controller("myContro", function ($scope, $interpolate) {
        $scope.user = {
            name: "",
            age: "",
            message: ""
        };

        $scope.user2 = {
            name: "",
            age: "",
            message: ""
        };

        $scope.messageTemp = "{{name}},您好,您今年{{age}}岁啦!";
        var template = $interpolate($scope.messageTemp);
        $scope.inputChange = function () {
            $scope.user.message = template({ name: $scope.user.name, age: $scope.user.age });
        };

        //// 下面通过watch监听实现ng-change一样的效果
        $scope.$watch("user2.name", function (newValue, oldValue) {
            $scope.getMessage(newValue, oldValue);
        });

        $scope.$watch("user2.age", function (newValue, oldValue) {
            $scope.getMessage(newValue, oldValue);
        });

        $scope.getMessage = function (value1, value2) {
            if (value1 != value2) {
                $scope.user2.message = template({ name: $scope.user2.name, age: $scope.user2.age });
            }
        }
    });
</script>

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
angularjs学习第一天笔记
    您好,我是一名后端开发工程师,由于工作需要,现在系统的从0开始学习前端js框架之angular,每天把学习的一些心得分享出来,如果有什么说的不对的地方,请多多指正,多多包涵我这个前端菜鸟,欢迎大家的点评与赐教。谢谢!
小小许
2018/08/30
2.4K0
angularjs学习第一天笔记
angularjs学习第五天笔记(第二篇:表单验证升级篇)
您好,我是一名后端开发工程师,由于工作需要,现在系统的从0开始学习前端js框架之angular,每天把学习的一些心得分享出来,如果有什么说的不对的地方,请多多指正,多多包涵我这个前端菜鸟,欢迎大家的点评与赐教。谢谢!
小小许
2018/08/30
1.7K0
angularjs学习第五天笔记(第二篇:表单验证升级篇)
第218天:Angular---模块和控制器
所有需要ng管理的代码必须被包裹在一个有ng-app指令的元素中 ng-app是ng的入口,表示当前元素的所有指令都会被angular管理(对每一个指令进行分析和操作)
半指温柔乐
2018/09/11
7330
angularJS学习之路(五)---表达式
AngularJS 表达式把数据绑定到 HTML,这与 ng-bind 指令有异曲同工之妙。
wust小吴
2019/07/08
6480
angularjs学习第八天笔记(指令作用域研究)
angularjs其作用域通过scope来实现,其取值有三种情况:true、false、{}
小小许
2018/08/30
4470
angularjs学习第八天笔记(指令作用域研究)
angularjs学习第三天笔记(过滤器第二篇---filter过滤器及其自定义过滤器)
您好,我是一名后端开发工程师,由于工作需要,现在系统的从0开始学习前端js框架之angular,每天把学习的一些心得分享出来,如果有什么说的不对的地方,请多多指正,多多包涵我这个前端菜鸟,欢迎大家的点评与赐教。谢谢!
小小许
2018/08/30
1.4K0
angularjs学习第三天笔记(过滤器第二篇---filter过滤器及其自定义过滤器)
angularjs学习第四天笔记(第一篇:简单的表单验证)
您好,我是一名后端开发工程师,由于工作需要,现在系统的从0开始学习前端js框架之angular,每天把学习的一些心得分享出来,如果有什么说的不对的地方,请多多指正,多多包涵我这个前端菜鸟,欢迎大家的点评与赐教。谢谢!
小小许
2018/08/30
1.8K0
angularjs学习第四天笔记(第一篇:简单的表单验证)
angularjs学习第二天笔记---过滤器
 您好,我是一名后端开发工程师,由于工作需要,现在系统的从0开始学习前端js框架之angular,每天把学习的一些心得分享出来,如果有什么说的不对的地方,请多多指正,多多包涵我这个前端菜鸟,欢迎大家的点评与赐教。谢谢!
小小许
2018/08/30
1.4K0
angularjs学习第二天笔记---过滤器
AngularJS Scope 的概念、特性和用法
在 AngularJS 中,Scope(作用域)是连接控制器和视图的关键概念之一。Scope 定义了应用中的数据模型,并且在控制器和视图之间建立了双向数据绑定。本文将详细介绍 AngularJS Scope 的概念、特性和用法,并提供一些示例帮助读者更好地理解和应用。
网络技术联盟站
2023/07/05
3150
AngularJS快速入门
记得第一次听说AngularJS这项很赞的Web的前端技术,那时还是2014年,年中时我们我的一个大牛兄弟当时去面试时,被问到了是否熟悉该技术,当时他了解和使用的技术比较多。我们询问他面试情况时,他给俺这个菜菜科普了该技术,印象比较深的是该技术支持前端MVC架构,可以完成大部分原有的后台工作,当时就觉得很神奇,但由于自身技术基础比较薄弱,没有太多时间和积累去学习新的技术,因而搁置了。在2016新年初始,正好有一些富余时间,正好学习下这个被称为就是“”两个大括号“”的前端框架(当前已经非常成熟,国内大部分公司
用户1216676
2018/01/24
2.7K0
AngularJS快速入门
AngularJS Bootstrap
AngularJS 的首选样式表是 Twitter Bootstrap, Twitter Bootstrap 是目前最受欢迎的前端框架。
陈不成i
2021/07/26
4.8K0
Angularjs基础(八)
AngularJS Bootstrap     AngularJS 的首选样式表是 Twitter Bootstrap ,Twitter Bootstrap 是目前最受欢迎的前端框架 Bootstrap     你可以在你的 AngularJS 应用中加入 Twitter Bootstrap,你可以在你的 <head>元素中添加如下代码:     <link rel="stylesheet" href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/boo
用户1197315
2018/01/19
3.2K0
angularjs学习第七天笔记(系统指令学习)
  您好,接着在昨天对简单指令学习了解以后,今天开始学习了解angularjs中的系统指令
小小许
2018/08/30
3.1K0
angularjs学习第七天笔记(系统指令学习)
【AngularJS】—— 13 服务Service
在AngularJS中有很多的服务,常用的比如$http,$location等等。 本篇文章会介绍一下的内容:   1 $http这种Angular提供的服务的使用   2 如何自定义服务,并总结服务需要注意的几个小点。   $http的使用   AngularJS为我们提供了很多种服务,$http用于发送http请求,动态的请求数据。   这样就需要使用web容器来运行代码了,先看看程序源码,视图方面还是跟普通的代码相同: <div ng-controller="myAppCtrl">
用户1154259
2018/01/17
1.5K0
【AngularJS】—— 13 服务Service
Angularjs基础(十)
ng-blur  描述:规定blur 事件的行为       实例:当输入框失去焦点的(onblur)时执行表达式:         <input ng-blur="count = count + 1" ng-init="count=0"/>         <h1>{{count}}</h1>       定义和用法           ng-blur 指令用于告诉AngularJS HTML 元素在失去焦点时须执行的表达式。           语法:<element ng-blur
用户1197315
2018/01/22
3.6K0
【AngularJS】—— 2 初识AngularJs(续)
前一篇了解了AngularJS的一些简单的使用,这里继续跟着w3c学习一下剩下的内容。   本篇根据w3cschool.cc继续学习AngularJS剩余的内容,包括:   1 事件   2 模块   3 表单   4 数据验证   5 bootstrap CSS风格   6 include包含其他页面   7 应用程序   8 参考手册   首先看一下html的事件   关于html的事件,文中给出了三个例子,点击、隐藏、显示。使用方法基本相同:   先看一下点击的例子,点击按钮后,会触发ng-clic
用户1154259
2018/01/17
2.5K0
8-angular 要点温习-1
angualr 要点温习 1、一些 ng 指令 ng-disabled true|false ,规定一个元素是否被禁止,但不会为隐藏 ng-keydown/ng-keypress/ng-keyup ng-mousedown/ng-seenter 鼠标穿过 2、一些 angular 内置方法/类比 jq angular.lowercase() angular.uppercase() angular.copy() 深克隆 angular.forEach() 类比 forEach var objs = [
西南_张家辉
2021/02/02
3.6K0
再谈angularJS数据绑定机制及背后原理—angularJS常见问题总结
ng-bind 单向数据绑定($scope -> view),用于数据显示,简写形式是 {{}}。
周陆军
2018/08/02
8.5K0
Angularjs1.X进阶笔记(1)—两种不同的双向数据绑定
html-Controller的双向数据绑定,在开发中非常常见,也是Angularjs1.x的宣传点之一,使用中并没有太多问题。
大史不说话
2019/03/01
3.8K0
Angularjs1.X进阶笔记(1)—两种不同的双向数据绑定
前端MVC学习总结(一)——MVC概要与angular概要、模板与数据绑定
张果
2018/01/04
15.9K0
前端MVC学习总结(一)——MVC概要与angular概要、模板与数据绑定
相关推荐
angularjs学习第一天笔记
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验