- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我似乎无法找到在ons-switch 中设置“checked”属性的正确方法。这样我就可以使用预先选中的选择框来设置用户配置页面。
文档:这是一个选中的开关,但如何使用 Angular Controller 中的变量来设置它?
例如,如果ons-switch 的语法如下 我本可以这样做:
我似乎无法按照文档中的需要将属性“checked”设置为没有 Angular 值。我也无法访问该变量,因为它是配置数组的一部分。
代码示例:
Controller :
var categInfo = [{Interest:'Classic', isChecked:true}, {Interest:'New', isChecked:false}];
html:
<ons-list-item ng-repeat="interest in categInfo" >
<span style="color: #666">{{interest.Interest}}</span>
<ons-switch modifier="list-item" var="{{interest.Interest}}" checked="{{interest.isChecked}}"></ons-switch>
</ons-list-item>
所以我想要的是 html 应该根据兴趣显示选中/未选中的按钮。isChecked 是 true 或 false。
最佳答案
首先,您需要将开关与 ng-model 绑定(bind),这将允许您直接从 Controller 管理 ons-switch
行为。在 Controller 内部设置变量 true
或 false
会自动更改开关状态的值,如果您从开关更改状态(AngularJS 绑定(bind))。
如果要查看开关状态,需要查看型号值。
这是一个CodePen example 。以及相关代码。
HTML
<div ng-controller="MyController">
<ons-switch ng-model="switch"></ons-switch>
<ons-button ng-click="changeSwitch()">Change switch status</ons-button>
</div>
Controller
ons.bootstrap()
.controller('MyController', function ($scope) {
$scope.changeSwitch = function() {
$scope.switch = !$scope.switch;
if($scope.switch)
alert('checked');
else
alert('unchecked');
};
});
编辑:开关数组示例
由于 Onsen UI 关于 ons-switch
元素初始化的错误,我建议您使用以下代码来实现您的开关。
<label class="switch">
<input type="checkbox" class="switch__input" checked>
<div class="switch__toggle"></div>
</label>
外观与 ons-switch
元素相同。此错误将在 Onsen UI 1.4 版本中修复,因此您可以在发布后再次开始使用 switch 元素。
对于一组开关的行为,它类似于单个开关。您仍然需要使用“ng-model”来绑定(bind)开关的状态。您正在使用 ng-repeat 来显示开关元素,因此,通过使用 ng-model="item.isChecked",每个元素都将与相对的 绑定(bind)数组内的 isChecked
值。在这里你可以找到一个工作CodePen example ,这是相关代码:
HTML
<div ng-controller="MyController">
<h2>What I am trying</h2>
<div ng-repeat="item in categInfo">
<div>This button should be {{item.isChecked}}</div>
<label class="switch">
<input ng-model="item.isChecked" type="checkbox" class="switch__input" checked>
<div class="switch__toggle"></div>
</label>
</div>
</div>
Controller
ons.bootstrap()
.controller('MyController', function ($scope, $timeout) {
//Need to go through the array and set as checked or not
$scope.categInfo = [{Interest:'Classic', isChecked:true}, {Interest:'New', isChecked:false}];
});
关于angularjs - 使用 Angular Controller 中的预定义值设置 ons-switch,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30566637/
我对我接管的项目有疑问。我正在转换其他人编写的 MS Access 应用程序并将其转换为 MySQL/PHP Web 应用程序。其中大部分已经完成,但是,当涉及到此应用程序的调度部分时,我处于停滞状态
我有一个带有 @Scheduled 注释的方法。此方法包含长时间运行、昂贵的操作。我担心当计划的方法开始运行时应用程序会变慢。有什么办法可以为预定方法分配优先级吗?在 Spring 中启动低优先级后台
我的大学有一个预订项目房间的网站;但除非你很幸运或者半夜醒着,否则要订到房间并不容易。因此,我编写了一个 JS 片段来填写所有必要的字段并提交表单。 但是我如何自动化这个过程呢? 我的目的基本上是加载
我正在评估处理大量排队消息的可能解决方案,这些消息必须在特定日期和时间交付给工作人员。执行它们的结果主要是对存储数据的更新,它们最初可能是也可能不是由用户操作触发的。 例如,想想你在一个假设的大型星际
@Scheduled documentation here声明 fixedRateString值可以是 the delay in milliseconds as a String value, e.g
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 4年前关闭。 Improve t
我有一个有趣的情况。我解析了几个新闻发布网站,想通过调度程序将它们保存到数据库中。但是保存时出现错误。由于交易后写条件 described here . 我的模型类是 @Entity @Table(n
我正在阅读 Java Concurrency in Practice 并遇到以下代码片段。 public static void timedRun(final Runnable r,
使用 Azure 数据工厂,是否可以对驻留在 Azure SQL 数据库中的多个(不是全部)表中的所有行执行预定的 1:1 复制/克隆到另一个 Azure SQL 数据库(在本例中为 Azure SQ
我是一名优秀的程序员,十分优秀!