JavaScript   发布时间:2022-04-16  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了郁闷!ionic中获取ng-model绑定的值为undefined如何解决大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

今天在ionic中使用Ng-model时候,在对应的controller里面获得值为undefined。以前在使用angularjs的ng-model绑定时候就可以拿到的啊,这就尴尬了,决定一探究竟。大家先看下面的一个demo。

在学习angularjs的ng-model的数据双向绑定时候,我们通过以下的代码拿到对应的ng-model的值:  

demo1

{{name}}

对应的js

var app = angular.module('myApp',[]); app.controller('myCtrl',function($scopE) { $scope.show=function(){ console.log($scope.Name);//可以正确的拿到页面上输入的值 console.log(allPrpos($scopE)); }; /*获取某个对象的属性*/ function allPrpos(obj) { // 用来保存所有的属性名称和值 var props = ""; // 开始遍历 for(var p in obj){ if(typeof(obj[p])=="function"){ // 方法 //console.log(obj[p]); }else{ // p 为属性名称,obj[p]为对应属性的值 props += p + "=" + obj[p] + "; "; } } // 最后显示所有的属性 console.log(props); } });

通过打印$scope对象,看到其属性的确包含一个name的键值对。但是在在ionic项目的时候,我们同样是这样拿的:

demo2

View view-title="Chats">
名字: {{name}}

在ionic对应的controller.js的对应的ChatsCtrl:

E) { $scope.show=function(){ console.log($scope.Name);//控制台打印undefined console.log(allPrpos($scopE)); }; });

在打印的$scope属性里面并未发现name,控制台打印undefined,页面上{{name}}却可以正常输出来,这是为何呢?估计很多ionic初学者在做项目中都遇到过这个情况,是不是angularjs的数据双向绑定在ionic中失效了?假如我这样写:  

demo3

View view-title="Chats"> 名字: {{name}}

在controller.js里面重新定义一个MyChatCtrl:

E) { $scope.show=function(){//点击button console.log($scope.Name);//控制台可以正常打印每次input输入框里面的值 console.log(allPrpos($scopE)); }; });

这样大家应该就看出一些端倪了吧,其实一切问题的根源就是scope。当使用Ng-model、ng-repeat等directive命令的时候,其本身会创建一个scope。其实,这涉及到ionic的controller创建时机问题,ionic视图路由里面创建的controller的scope的作用域要比下面的demo2中MyChatCtrl的scope的作用域要大;原来这两个scope是不同的,这也就解释了上面demo2为何拿到的值为undefind。发现问题了,如果解决这个问题呢?

scope作用域是可以继承的,js对象的属性也是继承的,所以我们可以稍微改下demo2,在刚才的ChatsCtrl先定义一个默认值:  

{text:""};

在页面上input的ng-model:

View view-title="Chats"> 名字: {{name}}

经过做如此处理后,再点击button发现可以正常打印$scope.name的值。如果你不想用对象的属性这样来做,你有可以把绑定的时候绑定到其父作用域的scope里面,demo2的ctrl不变,页面上的代码改为如下:

View view-title="Chats"> 名字: {{name}}

这样同样可以拿到$scope.name的值,至此问题解决。ng-repeat等如果出现此问题,同样可以如此处理。大家如果有其他的解决方案,欢迎留言提出。  

文章

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

大佬总结

以上是大佬教程为你收集整理的郁闷!ionic中获取ng-model绑定的值为undefined如何解决全部内容,希望文章能够帮你解决郁闷!ionic中获取ng-model绑定的值为undefined如何解决所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:ionicmodelngundefined
猜你在找的JavaScript相关文章
其他相关热搜词更多
phpJavaPython程序员load如何string使用参数jquery开发安装listlinuxiosandroid工具javascriptcap