knockout+bootstrap--一些复杂的应用合集
一、针对My97日历控件的绑定
普通绑定和特殊格式绑定(红色部分)
<!-- ko foreach: items -->
<td class="ruyeeTableTDLable"> <span>批准专业日期</span></td>
<td class="ruyeeTableDataCell">
<div class="input-group">
<input data-validation-engine="validate[maxSize[10]],validate[required],custom[date],"
data-bind="attr: { id: 'A7615' +$index(),value:A7615} " type="text" class="form-control">
<div class="input-group-addon ">
<span class="glyphicon glyphicon-calendar"
data-bind="attr: { onclick: 'WdatePicker({ el:A7615' + $index() + '})' }">
</span>
</div>
</div>
</td>
<td class="ruyeeTableTDLable"> <span>转业年份</span></td>
<td class="ruyeeTableDataCell">
<div class="input-group">
<input data-validation-engine="validate[maxSize[10]],validate[required],validate[date],"
data-bind="attr: { id: 'A7616' +$index(),value:A7616} " type="text" class="form-control">
<div class="input-group-addon ">
<span class="glyphicon glyphicon-calendar"
data-bind="attr: { id: 'WP_A7616_' +$index()} "></span>
</div>
</div>
</td>
<!-- /ko -->
/// <reference path="../knockout-3.2.0.js" />
var koList;
var deletedIds = Array();
var ViewModel = function (data, func) {
var self = this;
self.items = ko.mapping.fromJS(data.items);
self.struct = ko.mapping.fromJS(data.structV);
builLeftNva(self);
self.success = ko.observable();
self.success.subscribe(function (nv) {
var success = $.trim(nv);
) {
$('#success').modal('show');
}
});
self.canSubmit = ko.observable(false);
self.submit = function () {
if ($("#form_id").validationEngine("validate")) {
; i < koList().length; i++) {
//时间格式转换
koList()[i].A7615($('#A7615' + i).val());
koList()[i].A7616($('#A7616' + i).val());
}
$.ajax({
url: postOneModelActionUrl,
contentType: "application/json",
type: "POST",
data: ko.mapping.toJSON({ items: self.items, deletedIdList: deletedIds }),
success: function (response) {
self.success(response.Description);
},
async: false
});
}
};
self.closeSuccess = function () {
self.success('');
$('#success').modal('toggle');
};
self.deleteOne = function (item) {
self.items.remove(item);
if (item.ID() != null) {
deletedIds.push(item.ID());
}
}
self.addNew = function () {
//新增时的特殊处理
var js = ko.mapping.toJS(self.struct);
js.A7615 = getDateString();
js.A7616 = getDateString();
var newItem = ko.mapping.fromJS(js);
self.items.push(newItem);
func();
}
self.canSubmit(true);
$('#form_id').validationEngine();
koList = self.items;
//延时处理,解决KO性能问题
setTimeout(func, );
}
var refreshList = function () {
; i < koList().length; i++) {
//时间格式转换,如果是新增的(新增的ID为null)则无需转换
if (koList()[i].ID != null) {
$('#WP_A7616_' + i).click(function () {
WdatePicker({
dateFmt: 'yyyy-MM',
el: $('#A7616' + this.getAttribute('id').split('_')[2]).attr('id')
});
})
koList()[i].A7615(changeDateFormat(koList()[i].A7615()));
koList()[i].A7616(changeDateFormat(koList()[i].A7616(), null, null, null, false));
}
}
};
$(document).ready(function () {
$('#create').addClass('active');
$.ajax({
url: getStructActionUrl,
contentType: "application/json",
type: "POST",
data: JSON.stringify({ A01ID: QueryString.GetValue('a01id') }),
success: function (data) {
ko.attach("A76Model", new ViewModel(data, refreshList));
},
error: function (XMLHttpRequest, textStatus, errorThrown) {
switch (XMLHttpRequest.status) {
:
changeLocationToLogin();
break;
}
}
});
})
knockout+bootstrap--一些复杂的应用合集的更多相关文章
- 从零开始学数据分析,什么程度可以找到工作?( 内附20G、5000分钟数据分析工具教程大合集 )
从零开始学数据分析,什么程度可以找到工作?( 内附20G.5000分钟数据分析工具教程大合集 ) 我现在在Coursera上面学data science 中的R programming,过去很少接 ...
- 不容错过的UI设计素材大合集
免费PSD素材 TETHR by InVision 这是出自InVision的8款PSD文件,其中包含了100个模板和超过500个UI控件.来自InVision和UI8的设计师一同协作完成了这套UI ...
- 你想找的Python资料这里全都有!没有你找不到!史上最全资料合集
你想找的Python资料这里全都有!没有你找不到!史上最全资料合集 2017年11月15日 13:48:53 技术小百科 阅读数:1931 GitHub 上有一个 Awesome - XXX 系列 ...
- 最新最全的 Android 开源项目合集
原文链接:https://github.com/opendigg/awesome-github-android-ui 在 Github 上做了一个很新的 Android 开发相关开源项目汇总,涉及到 ...
- 超全的 Vue 开源项目合集,签收一下
超全的 Vue 开源项目合集,签收一下 xiaoge2016 前端开发 1周前 作者:xiaoge2016 链接: https://my.oschina.net/u/3018050/blog/2049 ...
- SQL Server技术内幕笔记合集
SQL Server技术内幕笔记合集 发这一篇文章主要是方便大家找到我的笔记入口,方便大家o(∩_∩)o Microsoft SQL Server 6.5 技术内幕 笔记http://www.cnbl ...
- 【Android】开发中个人遇到和使用过的值得分享的资源合集
Android-Classical-OpenSource Android开发中 个人遇到和使用过的值得分享的资源合集 Trinea的OpenProject 强烈推荐的Android 开源项目分类汇总, ...
- [Erlang 0122] Erlang Resources 2014年1月~6月资讯合集
虽然忙,有些事还是要抽时间做; Erlang Resources 小站 2014年1月~6月资讯合集,方便检索. 小站地址: http://site.douban.com/204209/ ...
- [Erlang 0114] Erlang Resources 小站 2013年7月~12月资讯合集
Erlang Resources 小站 2013年7月~12月资讯合集,方便检索. 附 2013上半年盘点: Erlang Resources 小站 2013年1月~6月资讯合集 小站地 ...
随机推荐
- 华为交换机sflow配置
华为交换机sflow功能配置 1.配置交换机的sflow流发送 [系统视图]sflow agen ip x.x.x.x 设置sflow输出源 [系统视图]sflow ...
- a* products
Experience of black-box testing on set-top-boxes/IP-connected devices, games consoles and tablets ht ...
- python-tab还是space?
今天把windows下的python代码传到服务器上,结果莫名其妙的报了一堆indent的错误 网上建议说用: python -m tabnanny filename.py 查一下 然后就用space ...
- nginx 之 grok 过滤
简介 前面我们的nginx日志编码使用的json,logstash直接输入预定义好的 JSON 数据,这样就可以省略掉 filter/grok 配置,但是在我们的生产环境中,日志格式往往使用的是普 ...
- Swift编程语言简介
这篇文章简要介绍了苹果于WWDC 2014发布的编程语言Swift. ...
- ArcGIS for Android_离在线一体化核心技术基本流程
核心思想: a.数据首先存储于ArcSDE中,要素添加GlobleID,图层数据启用数据归档或开启版本化.b.然后将ArcSDE数据库托管于ArcGIS for Server作为数据存储.c.在Arc ...
- NotePad++ 调试PHP代码中文显示乱码
最近在NotePad++上调试PHP代码,按照示例代码进行调试,结果在显示中文的时候显示一堆乱码,于是上网百度,有2种方法可以解决: 按调试方式有2种方法: 1.菜单插件-NppExec: " ...
- java虚拟机之回收方法区
在java虚拟机中并没有规范规定需要对方法区即是新生代进行垃圾回收, 主要是这些区域的回收性价比极低, 一般在新生代中一般垃圾回收中可以达到70%到95%. 其中永久代中的垃圾回收主要回收的是两个 ...
- js中的break ,continue, return (转)
面向对象编程语法中我们会碰到break ,continue, return这三个常用的关键字,那么关于这三个关键字的使用具体的操作是什么呢?我们在使用这三关键字的时候需要注意和需要理解的规则是什么呢? ...
- sublime 中文乱码
一.安装Package Control 使用Sublime Text2首先就要安装Package Control,这样就能使用丰富的插件包了 (1)访问Package Control站点按照提示复 ...