今天介绍一下使用Aurelia binding 模块绑定HTML属性/事件的方式。我们依然使用之前创建的代码例子。

Aurelia binding 绑定属性或者方法的通用模式就是 XXX.command="expression"

XXX如 属性 value, 如方法click,blur

command 如 bind, two-way, one-time 等

expression 即js表达式

一. 绑定属性

attribute.command=”expression”

attribute: html属性.

command: one of Aurelia's attribute binding commands:

one-time: 单向绑定,数据模型=>视图, 仅一次.

to-view / one-way: 单向绑定,数据模型=>视图

from-view: 单向绑定,视图=>数据模型.

two-way: 双向绑定,数据模型<=>视图

bind: 自动选择绑定模式,表单控件是two-way,其他控件基本是to-view方式.

expression: js表达式.

通常自己写组件的话,使用bind就行了,如果只需要用来显示数据,并且不会修改,可以使用one-time来提高渲染效率

自己写几次比较一下就能掌握使用方法了。

二. 事件绑定方式

event.command="expression"

event: DOM事件,但书写的时候不包含'on'.

command:

trigger: 直接向元素绑定事件,当事件触发,handler会执行

delegate: 向顶层元素绑定事件,当事件触发时(冒泡),会自行找到初始触发元素.

capture: 向顶层元素绑定事件,当事件触发时,在事件捕获过程中触发

expression: js 表达式. 使用$event 可以在绑定的函数中获取事件对象

在用delegate和trigger绑定handler的时候,Aurelia默认调用preventDefault(),如果不想调用preventDefault, 那么在handler里返回true即可。

delegate VS trigger

delegate和trigger很相像,那么什么时候用delegate,什么时候用trigger呢?

简单点说就是能使用delegate就使用delegate 除非不能使用delegate。

delegate只适用于会冒泡的事件,如click, 像blur, focus 等不会冒泡的事件,delegate不适用;这个时候就要使用trigger

当你的button遇到下面两种情况的时候,就需要使用trigger

1. button需要被disable

2. button的元素内容是由其他的元素组成(非纯文本)

在ios中遇到如下情况使用trigger

ios 除了元素a, button, input 和select,其他元素click事件不会冒泡。如果你对一个div绑定click事件,那么就需要使用trigger。

三. 方法绑定方式

在自定义组件的时候,我们可能会想要重写组件的某个方法,或者为组件添加不同的回掉,这时候我们就可以为自定义组件添加一个bindable的属性来

绑定一个方法。

XXX.call="function()"

XXX: 是你在组件里定义的bindable 属性

call是特定的语法

function 是你在父组件中定义的方法,并想要传递给自定义组件

在自定义组件内部定义了两个bindable的属性go, callback,当外部父组件添加该组件的时候,可以向go/callback 添加定义了的方法。

其实如果了解箭头函数的写法的话,就可以快速理解这个function 的绑定方式。 property = ()=> {}

四. reference

Aurelia binding 模块可以允许用户向dom元素(或其他元素)添加一个reference

写法 XXX.ref ="expression"

element.ref="expression": 向dom元素添加一个reference(同 ref="expression")

attribute-name.ref="expression": 向自定义属性的view-model添加一个reference (custom-attribute 会在之后的篇章介绍)

view-model.ref="expression": 向自定义元素的view-model 添加reference

view.ref="expression": 向自定义元素的view实例添加reference (非html元素)

controller.ref="expression": 向自定义元素的controller 添加reference

注意: 这边dom的ref 是添加在自定义元素内部的,view, viewmodel, controller 的ref是添加在父组件上

这边文本框后面显示的是文本框里的内容,这个值是从文本框的ref上拿到的

控制台里的输出,可以看到viewmodel对象,view以及controller,这就是通过添加的ref 拿到的

五. String Interpolation

string interpolation 字符串插补,如果熟悉模板字符串语法的话就很容易上手使用这个功能。

语法: ${property}

如果属性 property 对应的值是null 或者undefined,那么会显示空字符串。

字符串插补的默认绑定方式是to-view.

也可以显示的通过textcontent.bind 的方式去显示绑定内容, 也可以把bind 替换为其他绑定方式,如to-view, one-way, two-way...

六. Contextual Properties

binding模块可以根据不同的上下文,来获取绑定在你的模板(自定义组件等别称)上的属性

  • $this - view-model
  • $parent - Explicitly accesses the outer scope from within a compose or repeat template. You may need this when a property on the current scope masks a property on the outer scope. Chainable- eg $parent.$parent.foo is supported.
  • $event - delegate或者trigger 绑定的dom事件
  • $index - 元素在一个循环重复的模板中的索引
  • $first - 如果元素是循环中的第一个元素,那么这个值为true
  • $last - 如果是最后一个元素,那么这个值为true
  • $even - 如果索引是偶数,那么这个值为true
  • $odd - 如果索引是奇数,那么这个值为true

七. 表达式语法 Expression Syntax

基本JS里的表达式,都能通用。

  • 与符号 & 代表的是Binding Behavior (而不是二进制与)
  • 或符号 | 代表的是 ValueConverter (而不是二进制或)

Aurelia binding的更多相关文章

  1. 创建Aurelia项目

    什么是Aurelia? Aurelia 是一个新的开源的,基于web标准的mvvm框架,是一个现代化的js模块的集合. Aurelia提供了丰富的plugin,例如国际化,验证,模态框,UI可视化等. ...

  2. org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):

    org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): da.huying.usermanag ...

  3. WPF binding 参考

    Introduction This is an article on WPF Binding Cheat Sheet. Some of the Binding won't work for Silve ...

  4. 十五天精通WCF——第一天 三种Binding让你KO80%的业务

    转眼wcf技术已经出现很多年了,也在.net界混的风生水起,同时.net也是一个高度封装的框架,作为在wcf食物链最顶端的我们所能做的任务已经简单的不能再简单了, 再简单的话马路上的大妈也能写wcf了 ...

  5. Binding笔记

    Binding基础  绑定某个对象的属性值到控制上,写法如下: public class Order : INotifyPropertyChanged//只要实现此接口 { public event ...

  6. Data Binding使用技巧

    Data Binding 根据变量,自动赋值到各widget. How 1.编写layout文件,这里的layout为: act_data_bind_demo.xml 这里需要先准备变量 在具体的wi ...

  7. WPF之Binding初探

    初学wpf,经常被Binding搞晕,以下记录写Binding的基础. 首先,盗用张图.这图形象的说明了Binding的机理. 对于Binding,意思是数据绑定,基本用法是: 1.在xmal中使用 ...

  8. [XAML]类似WPF绑定的Binding的读取方法

    在WPF的XAML里,依赖属性可以使用基于BindingBase之类的MarkupExtensin 读取XAML时,会自动的把该BindingBase转换为BindingExpressionBase ...

  9. [ASP.NET MVC 小牛之路]15 - Model Binding

    Model Binding(模型绑定)是 MVC 框架根据 HTTP 请求数据创建 .NET 对象的一个过程.我们之前所有示例中传递给 Action 方法参数的对象都是在 Model Binding ...

随机推荐

  1. 省钱版----查找 IoT 设备TTL线序__未完待续

    作者:仙果 原文来自:省钱版—-查找 IoT 设备TTL线序 省钱版----查找 IoT 设备TTL线序__未完待续 缘由 在IoT固件调试分析的过程中,建议首先在IoT设备的板子上焊接调试线,这是能 ...

  2. 5.AutoCompleteTextView、自定义广播

    新建信息 布局:自动出来的是系统的组件,里面是listview,写ontextchanglis也行 <LinearLayout xmlns:android="http://schema ...

  3. 微信小程序的wx-charts插件-tab选项卡

    微信小程序的wx-charts插件-tab选项卡 效果: //index.js var wxCharts = require('../../utils/wxcharts-min.js'); const ...

  4. 记录python题

    def mone_sorted(itera): new_itera = [] while itera: min_value = min(itera) new_itera.append(min_valu ...

  5. 爬虫不过如此(python的Re 、Requests、BeautifulSoup 详细篇)

    网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本. 爬虫的本质就是一段自动抓取互联网信息的程序,从网络获取 ...

  6. iReport 5.6.0 安装包下载&安装

    iReport 5.6.0 下载 方式有两种: 1.在官网社区上下载,下载地址:https://community.jaspersoft.com/project/ireport-designer/re ...

  7. java-vip介绍

    大叔Springboot+微服务+持续集成和交付VIP(价格:5000元) springboot部分 微服务部分 持久集成和交付部分 springboot部分 视频课(10讲) 项目源代码(api r ...

  8. Leetcode 1-10

    这篇文章介绍Leetcode1到10题的解决思路和相关代码. 1. Two sum 问题描述:给定一个整数数组,返回两个数字的索引,使它们加起来等于一个特定的目标. 例子: Given nums = ...

  9. Java中的instanceof和isInstance基础讲解

    1. instanceof 是一个操作符 使用方法: ? 1 2 if(a instanceof B){ } 表示:a 是不是 B 这种类型 2. isInstance是Class类的一个方法 ? 1 ...

  10. 【Jquery系列】之Jquery 选择器

    1   概述 本篇文章为穿插文章,ASP.NET MVC系列目前写了如下几篇: 详解google Chrome浏览器(理论篇) 详解Google Chrome浏览器(操作篇)(上) 详解Google ...