位置: 编程技术 - 正文

认识Knockout及如何使用Knockout绑定上下文(认识iu)

编辑:rootadmin

推荐整理分享认识Knockout及如何使用Knockout绑定上下文(认识iu),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:认识克课件,认识iu,认识iu,认识ue,认识ei,认识ue,认识ue,认识克教案,内容如对您有帮助,希望把文章链接给更多的朋友!

Knockout介绍

Knockout简称ko,是一个轻量级的javascript类库,采用MVVM设计模式(即Model、view、viewModel),简单优雅的实现了双向绑定,实时更新,帮助您使用干净的数据模型来创建丰富的、响应式的用户界面。

Knockout有三大核心特性:

1.优雅的依赖跟踪(Elegant dependency tracking):任何时候数据模型的变化都会自动更新相应的UI部分;

2.声明式绑定(Declarative bindings) : 简单的将UI和你的数据模型关联起来,你就可以创建复杂的动态UI;

3.高度可扩展性(Trivially extensible) : 只需几行代码实现一个自定义的行为来作为声明式绑定;

其他优点:

1.纯净的javascript代码;

2.可以随时添加到你现有的web应用中;

3.轻量级,GZIP后只有K;

4.能够工作于几乎所有主流浏览器((IE 6+, Firefox 2+, Chrome, Safari, Edge, others);

ko采用的是MVVM设计模式,即model view viewModel。

简单的例子

就是这么简单,你不必写代码来更新text内容,它会在数组长度改变时自动更新,与此类似,如果我们想利用数组长度控制按钮的可用性仅仅需要:

下面接着给大家介绍使用Knockout绑定上下文

Binding context

binding context是一个保存数据的对象,你可以在你的绑定中引用它。当应用绑定的时候,knockout自动创建和管理binding context的继承关系。这种层次结构的根引用你指定的viewModel参数(ko.applyBindings(viewModel))。

然后每次使用一个控制流如with或者foreach 来创建一个子节点binding context引用嵌套的viewModel data。

认识Knockout及如何使用Knockout绑定上下文(认识iu)

$parent

$parents

这是一个数组,代表了所有的父节点view models

$parent[0] : 代表父节点;

$parent[1] : 代表祖父节点;

$parent[1] : 代表曾祖父节点;

.....以此类推

$root

它是root context的根节点视图模型对象,一般是通过ko.applyBindings指定的,相当于$parents[$parents.length - 1]。

$component

如果你在一个特定的组件模板的上下文中,$component指定的是那个component,它的指定组件相当于$root,在嵌套的组件情况下,它代表了最邻近的一个组件。

$data

它代表了当前上下文中的viewModel对象,$data和$root是相当的。在嵌套的binding context中,这个参数将设置到当前的数据项。

$data是非常有用的,例如,当你想引用viewModel本身而不是viewModel的属性的时候。

它是一个在foreach绑定中的数组的从0开始的索引条目。不想其他的context属性,$index是observable的,即会随着数组item的更新而更新。

$parentContext

指定了父节点级别的binding context对象,与$parent不同的是,它是在父节点中指定数据而不是binding context。

$rowData

它是在当前上下文中,原viewModel的值,通常它相当于$data,但是,如果viewModel被ko以observable来修饰,$data是unobservable的,而$rowData是observable的。

如何解决easyui自定义标签 datagrid edit combobox 手动输入保存不上 使用onEndEdit事件(该事件可以获取到editor对象,onAfterEdit事件获取不到Editor对象)通过editor拿到输入数据并保存。intci=0;for(Columncol:columnList){for(Comboboxcbb:c

JS插件overlib用法实例详解 本文实例讲述了overlib用法。分享给大家供大家参考,具体如下:overLIB是一个生成提示框与弹出菜单等页面效果的一段非常优秀的JS代码。它可以简单的

JavaScript动态设置div的样式的方法 有时候需要根据需要动态设置div的样式,当然对于稍有经验的javascript开发者来说,这一切都是那么的简单,但是对于初学者或者说没有相关经验的开发

标签: 认识iu

本文链接地址:https://www.jiuchutong.com/biancheng/385560.html 转载请保留说明!

上一篇:详解Document.Cookie(详解各种汽油一吨等于多少升)

下一篇:如何解决easyui自定义标签 datagrid edit combobox 手动输入保存不上(easyui-dialog)

  • 航天金税盘使用说明
  • 企业可否自行决算利润
  • 先申报财务报表还是企业所得税汇算清缴
  • 本月销售商品的实际成本怎么算
  • 银行承兑的商业汇票计入什么科目
  • 补交土地使用税到大厅怎么申报
  • 单利率和复利率excel计算公式
  • 主营业务收入和销售收入
  • 进料加工手册核销是什么意思
  • 人力资源服务费发票可以抵扣吗
  • 企业撤资的所得税处理
  • 非营利性科研机构接受企业基础研究收入免征企业所得税
  • 合并业务的好处
  • 价外收取的返还利润是什么意思
  • 防洪费怎么申报
  • 持有至到期投资核算内容
  • 房地产开发临时用电
  • 税务社保扣取300干嘛的
  • 医院其他收入包括哪些项目
  • 营改增之后有了利息收入核算税费?
  • 房屋购买安装电梯可以抵扣吗?
  • 领定额发票需要报税吗
  • 大众创业的后果
  • 公司不动产管理办法
  • 销售方开票不填开户行
  • 先亏后盈法案例分析
  • 两处拿工资的缴税问题
  • 不征收增值税的项目有哪些
  • 华硕笔记本预装win10改装win7,有图文教程
  • 电信网络网速变快设置
  • 按简易办法征收增值税的行为有
  • 所有者权益变动表范本
  • 股权转让个税计算方法 未分配利润
  • 工业会计账务处理
  • 企业怎么知道增值税的核定方法
  • 激光点图片
  • phpsession和cookie
  • Mybatis+Servlet+Mysql 整合的一个小项目:对初学者非常友好,有助于初学者很快的上手Java Web
  • python快速检索
  • php制作验证码
  • 事业单位新会计制度固定资产
  • 命令查看系统信息
  • 注销的公司需要清算吗
  • 企业所得税算法例题解析
  • mysql启动器
  • 培训属于什么服务
  • 增值税及附加税费申报表附列资料一
  • 因质量问题免费退货
  • 建筑施工安全费用提取标准
  • 暂估入库的税务怎么处理
  • 生产企业支付的房租怎么入账
  • 固定资产清理的累计折旧怎么算
  • 四技合同是什么?
  • 进项税额准予抵扣是什么意思
  • 小规模纳税人抵扣税控盘增值税怎么申报
  • 工资完税证明怎么开
  • mysql主键冲突但数据不存在
  • 使用mysql进行模糊查询
  • 下载win10 32位
  • ipad和iPhone的mac地址区别
  • alg.exe是什么程序
  • win10开机自动启动软件怎么设置
  • linux重启命令网卡
  • win7系统防火墙无法关闭
  • IE6,IE7和firefox对DIV的支持区别
  • sequelize join
  • 搭建nfs
  • Node.js中的全局变量有哪些
  • java线程池创建
  • 按钮用于控制电路
  • unity的vs
  • unity ugui ngui
  • Python3使用requests包抓取并保存网页源码的方法
  • Android 4.4 Dialog 被状态栏遮挡的解决方法
  • 快速排序的算法流程图
  • 夫妻双方房子契税怎么算
  • 税务局税收风险排查总结
  • 蜀山区税务局工资待遇
  • 国外高速公路收费站
  • 建筑业统一发票税率
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设