- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个使用 angularJs 的表单,我主要关心的是带有 ng-option 的 select 标签 让我给你快速浏览一下表格,然后会解释我的问题。 注意:我删除了不必要的部分,例如 div 和类,因为这不是布局问题。
<form role="form" name="feedbackForm" ng-submit="sendFeedback()" novalidate>
<!-- ---------------- SELECT ------------------->
<label>
<input type="checkbox" name="approve" value="" ng-model="feedback.agree">
<strong>May we contact you?</strong>
</label>
<div ng-show="feedback.agree" ng-model="feedback.myChannel">
<select class="form-control c-select" name="select" ng-model="feedback.myChannel" ng-options="channel.value as channel.label for channel in channels">
<option value="">Select a method</option>
</select>
</div>
<!-- --------------------TEEPHONE ---------------------->
<label for="telnum">Contact Tel.</label>
<input type="tel" id="areacode" name="areacode" ng-model="feedback.tel.areacode">
<input type="tel" id="telnum" name="telnum" ng-model="feedback.tel.number">
<!-- ------------- EMAIL ------------------------>
<label for="emailid" class="col-sm-2 control-label">Email</label>
<div class="col-sm-10">
<input type="email" id="email" name="email" ng-model="feedback.email" >
然后我将如下所示显示我的值,仅用于开发目的
<p> Contact by: {{ feedback.myChannel }} </p>
<p> feedback.agree: {{'( ' + feedback.agree + ' )'}} </p>
<p> feedback.myChannel: {{'( ' + feedback.myChannel + ' )'}} </p>
在 Controller 和 ng-option 中我有:
$scope.channels = [
{ value:"Tel", label:"Tel" },
{ value:"Email", label:"Email" },
{ value:"Tel & Email", label:"Tel & Email" }
];
然后为了将反馈推送到服务器,我创建了这个对象:
$scope.feedback = { myChannel:"", firstName: '', lastName: '', agree: false, email: '' };
这里有一些图片显示所有这些变量和值都已正确提供给网站。
我的问题是:我正在尝试使用 $scope.feedback.myChannel
来满足其他需求,但在我的 Controller 上找不到,而我在我的表单中使用它。
这一行什么也没给出。也许是一个空字符串:
console.log('myChannel = ' + $scope.feedback.myChannel);
所有这些 if 都不工作,控制台中没有任何显示:
if($scope.feedback.myChannel == "Tel" || $scope.feedback.myChannel === "Tel & Email"){
console.log($scope.feedback.myChannel);
};
if($scope.feedback.myChannel === "Email" || $scope.feedback.myChannel === "Tel & Email"){
console.log($scope.feedback.myChannel);
};
这个没有做它应该做的事:
if(!$scope.feedback.agree){ $scope.feedback.myChannel = ''; };
这个 console.log 给出了意外的值:
console.log('1: ' + $scope.feedbackForm.myChannel) // undefined
console.log('2: ' + $scope.feedback.myChannel); // nothing .. perhaps an empty string
最佳答案
嗯,根据你的plnkr ,你正在清理你的 object
然后你尝试做一个 console.log()
,当然它会是一个空字符串。
还有:
console.log('1: ', $scope.feedbackForm.myChannel)
未定义,因为在您的表单中没有包含此名称
的标记
来调用选择
(由于您将其命名为 name="select"
),您应该执行以下操作:
console.log('1: ', $scope.feedbackForm.select)
工作 DEMO .
关于angularjs - 如果我可以在我的 html 页面中使用 $scope 值,为什么我不能在我的 Controller 中使用它?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38447492/
我在这里有我的 javascript 代码: define(['controllers/controllers', 'services/alerts'], function(module) {
的意义是什么scope = scope-token *( SP scope-token ) scope-token = 1*( %x21 / %x23-5B / %x5D-7E ) 在 RFC6749
我是 AngularJS 的新手。我试图找出这两个 Controller 定义之间的区别: app.controller('simpleController', ['$scope', function
似乎所有 Guice 的开箱即用 Scope 实现本质上都是基于线程的(或完全忽略线程): Scopes.SINGLETON和 Scopes.NO_SCOPE忽略线程并且是边缘情况:全局范围和无范围。
如果这个问题涉及的是一个常见问题,我很抱歉,但我发现这个问题非常抽象,并且无法真正为其构建一个好的 Google 搜索词。 我试图理解并找到 Maven 中提供的依赖项的用例。我的想法是这样的: 假设
假设我有以下 Controller angular.module('scopeExample', []) .controller('MyController', ['$scope', func
当前在TmThemeEditor上注册的243种配色方案中, 我注意到几乎没有人使用范围选择器运算符。 对于以下情况,运算符非常有用: (text.html | text.xml) & (meta.t
我有一些行为不符合预期的代码......我在 AngularJS Controller 中有一个事件监听器,如下所示: $scope.$on("newClipSelected", function(e
首先,如果帖子太长,我深表歉意。另外,为了以防万一这会以某种方式干扰您可能给我的答案,我不会以通常的方式定义我的 Controller 。相反,我关注http://www.technofattie.c
我有一个模式,其中许多项目类型都是“可编辑的”。这意味着我有很多模板(每种可编辑项目类型一个),这些模板期望具有唯一的字段,但具有通用功能(编辑、保存、取消编辑、删除等)。这些常见功能导致 Contr
$evalAsync 和 $applyAsync 之间有什么区别?我的理解是,当我从指令中使用 $evalAsync 时,表达式将在浏览器呈现之前进行计算。 举个例子,如果我想滚动到页面上的特定位置但
我试图为一个 $scope 变量提供另一个 $scope 变量的值。有人能告诉我出了什么问题吗?查看简单的 plunker 了解详细信息: http://plnkr.co/edit/TlKnd2fM5
我有以下一段 Angular 代码 $scope.prepare = function(){ $scope.elems = [1,2,3]; }; $scope.action = functio
我正在关注 Angularjs 的官方教程,但我陷入了第 2 步。 这是一个片段,我不明白 $scope:scope 的含义, describe('PhoneListCtrl', function()
根据文档, Global: Component is shared among all users. Session: Separate instances of the component are
显示作用域变量,类似于 Angularjs 中的 ng-repeat 元素 这些是我的范围变量 $scope.published = true; $scope.count = 3; 我还有一个名为 l
我是 Angular 的新手,我想在普通的 javascript 中做一些非常简单的事情,但我无法找到如何在 Angular 中正确地做到这一点! 我想设置一个通用函数来清除输入文本字段: 我有这个
在article中发现了这样一个idea : Notice how the value function takes the scope as parameter (without the $ in
注释部分将位于 $scope.$on 下。我需要将 options 返回到我保存 $scope.$emit 的地方。请帮助!!! if (gridConfig.Batch) {
我有一个带有 2 个作用域的 Controller : app.controller('search', function($scope) { $scope.value1 = '';
我是一名优秀的程序员,十分优秀!