【转】Polymer API开发指南 (二)(翻译)
原文转自:http://segmentfault.com/blog/windwhinny/1190000000596258
公开 property
当你公开一个 Polymer 元素的 property 名字时,就等于把这个 property 设置为公开API了。公开 property 会有如下的特性:
- 支持声明数据双向绑定
- 通过声明,property 将会按照名称一样的 html attribute 初始化数据
- property 的值可以反射到元素对应的attribute上
注: property 名称是大小写区分的,但是 attribute 却不是。polymer 将会把 property 和 attribute 一一对应,所以你不能声明两个只有大小写区别的 attribute(比如:name 和 NAME);
有两种方法可以绑定 property :
- 将property名放在
polymer-element
元素attributes
attribute里 - 将property名放在构造原型的
publish
里
举个例子,这里一个元素,通过设置attributes
来设置三个公开的property,foo
,bar
,baz
。
<polymer-element name="x-foo" attributes="foo bar baz">
<script>
Polymer('x-foo');
</script>
</polymer-element>
下面这个例子用到了publish
:
<polymer-element name="x-foo">
<script>
Polymer('x-foo', {
publish: {
foo: 'I am foo!',
bar: 5,
baz: {
value: false,
reflect: true
}
}
});
</script>
</polymer-element>
主要注意的是baz
使用了不同的声明方法来开启 attribute 反射功能。
一般来说,我们更建议使用attributes
,因为这是声明式的,而且开发者可以很容易的通过元素标签来看到所有元素暴露出来的API。
只有以下情况,我们才建议使用publish
式声明:
- 元素公开的property太多,把所有property名放在
attributes
会显得有点奇怪。 - 需要设置property的初始值。
- 你需要设置attribute到property之间的反射
property 的默认值
默认情况下,在attributes
里设置的property的值为null
。
<polymer-element name="x-foo" attributes="foo">
<script>
// x-foo 有一个名称为 foo 的 property ,默认值为 null
Polymer('x-foo');
</script>
</polymer-element>
polymer会将foo添加到元素prototype
上,并设置为null
。
你可以通过在元素的prototype
上显式property的默认值。
<polymer-element name="x-foo" attributes="bar">
<script>
Polymer('x-foo', {
// x-foo 有一个名称为 bar 的 property ,默认值为 false
bar: false
});
</script>
</polymer-element>
或者可以全部移到publish
里:
<polymer-element name="x-foo">
<script>
Polymer('x-foo', {
publish: {
bar: false
}
});
</script>
</polymer-element>
如果property的默认值为object或者array的时候,则需要放在created里初始化,这样就保证了在不同的实例里值的引用都不同。
<polymer-element name="x-default" attributes="settings">
<script>
Polymer('x-default', {
created: function() {
// create a default settings object for this instance
this.settings = {
textColor: 'blue';
};
}
});
</script>
</polymer-element>
通过设置 attribute 来配置元素
Attribute 为我们提供了一种简单的方法来直接配置元素。我们可以通过设置attribute为元素提供一个初始值,从而来自定义它。
<x-foo name="Bob"></x-foo>
如果元素的property不是字符串,那么polymer会自动判断它的类型,并将其转换为合适的格式。
除非开启了attribute反射,否则Attribute到property的连接是单向的,property改变并不会影响到attribute。
注:不要将数据绑定和attribute配置混淆。数据绑定是引用式的,这就意味着值并不会被序列化和反序列化。
探测property类型
Polymer会根据property的默认值,来判断它的类型,并将相绑定的attribute转换为此类型。
例如一个元素x-hint
有一个property名为count
,默认值为0
。
<x-hint count="7"></x-hint>
因为count
的默认值为0
,所以polymer将字符串"7"
转换成了数字7
。
如果一个property是对象或者数组,则我们可以用JSON字符串来表示它。
<x-name fullname='{ "first": "Bob", "last": "Dobbs" }'></x-name>
这就相当于在JS里设置元素的propertyfullname
。
xname.fullname = { first: 'Bob', last: 'Dobbs' };
我们可以在publish
或者created
回调中设置默认值。下面这个元素使用了三种方法。
<polymer-element name="hint-element" attributes="isReady items">
<script>
Polymer('hint-element', {
// hint that isReady is a Boolean
isReady: false,
publish: {
// hint that count is a Number
count: 0
},
created: function() {
// hint that items is an array
this.items = [];
}
});
</script>
</polymer-element>
重要:对于类型为对象或者数组的property,应该始终在created
回调中初始化。如果直接在构造原型上设置默认值的话,那么在不同的实例里就会遇到 "shared state" 错误。
Property 反射到 Attribute
Property的值可以反射到对应的Attribute上。例如,如果在一个元素上开启了对name
的反射,那么this.name="Joe"
的效果就等于 this.setAttribute('name','Joe')
,元素将会自动的更新DOM。
<x-foo name="Joe"></x-foo>
Property 反射只在某些特殊的场景有用,所以它默认是关闭的,它最常用的地方就是用attribute来控制元素的样式。
待续...
【转】Polymer API开发指南 (二)(翻译)的更多相关文章
- Polymer API开发指南 (二)(翻译)
公开 property 当你公开一个 Polymer 元素的 property 名字时,就等于把这个 property 设置为公开API了.公开 property 会有如下的特性: 支持声明数据双向绑 ...
- 【转】Polymer API开发指南 (一)(翻译)
原文转自:http://segmentfault.com/blog/windwhinny/1190000000592324 翻译的不好,轻拍 Polymer是google的一款前端开发框架,其基于Sh ...
- Spark Streaming和Kafka整合开发指南(二)
在本博客的<Spark Streaming和Kafka整合开发指南(一)>文章中介绍了如何使用基于Receiver的方法使用Spark Streaming从Kafka中接收数据.本文将介绍 ...
- 谷歌拼音输入法扩展API开发指南
为了帮助开发者在谷歌拼音输入法的基本输入功能基础上,开发和定义更丰富的扩展输入功能,谷歌拼音输入法提供了以Lua脚本编程语言为基础的输入法扩展API.利用输入法扩展API,开发者可以编写自定义的输入功 ...
- Web报表工具FineReport的JS API开发(二)
上次介绍FineReport的JS API中的第一类开发--FR,这次就来介绍一下FS和contentWindow类的开发. 1 FS FS是数据决策系统中的js接口,比如说FS.tabPane.ad ...
- 百度地图API开发指南
简介什么是百度地图API? 百度地图API是一套由JavaScript语言编写的应用程序接口,它能够帮助您在网站中构建功能丰富.交互性强的地图应用.百度地图API包含了构建地图基本功能的各种接口,提供 ...
- Google maps API开发(二)(转)
这一篇主要实现怎么调用Google maps API中的地址解析核心类GClientGeocoder: 主要功能包括地址解析.反向解析.本地搜索.周边搜索等, 我这里主要有两个实例: 实例一.当你搜索 ...
- CTP API 开发之二 :制作CTP java版 API
目前上期技术CTP系统提供的API版本是C++版本 SWIG是一个能将C/C++接口转换为其他语言的工具,目前可以支持Python,Java,R等语言. 本文主要介绍Windows 32/64位平台下 ...
- 来自HeroKu的HTTP API 设计指南(中文版)
原文转自:http://get.jobdeer.com/343.get 来自HeroKu的HTTP API 设计指南(中文版) 翻译 by @Easy 简介 本指南中文翻译者为 @Easy ,他是国内 ...
随机推荐
- A-Making the Grade(POJ 3666)
Making the Grade Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4656 Accepted: 2206 ...
- input固定定位后,当input框获取到焦点时,会离开手机软键盘的解决方法
前些天做页面时候遇到这样一个问题,将input框用position:fixed固定定位在最底部的时候,当Input获取焦点的时候,input框离开了手机软键盘,而不是吸附在软键盘上,效果如下图: 找了 ...
- Eclipse中SVN的安装步骤(两种)和使用方法 [转]
一.给Eclipse安装SVN,最常见的有两种方式:手动方式和使用安装向导方式.具体步骤如下: 方式一:手动安装 1.从官网下载site-1.6.9.zip文件,网址是:subclipse.tigri ...
- asp.net下ajax.ajaxMethod使用方法
使用AjaxMethod可以在客户端异步调用服务端方法,简单地说就是在JS里调用后台.cs文件里的方法,做一些JS无法做到的操作,如查询数据库. 使用AjaxMethod要满足一下几点: 1.如果 ...
- 标签视图控制器UITabBarController
标签视图控制器 UITabBarController FirstViewController*first = [[FirstViewController alloc] init]; //创建一个UIT ...
- HTTPS是如何保证连接安全,你知道吗?
HTTPS协议的工作原理是什么?”这是我在数天前工作项目中需要解决的问题. 作为一名Web开发者,我当然知道 HTTPS 协议是保障用户敏感数据的好办法,但并不知道这种协议的内在工作机制. 它怎么保护 ...
- NOIP2010解题报告
今天状态不错..1个小时AC了前3题,第四题第一次也拿到了80%的分数,后来换了算法才拿到全部分数.. 第一题: 小晨的电脑上安装了一个机器翻译软件,他经常用这个软件来翻译英语文章. 这个翻译软件的原 ...
- wp8.1 Study11:APP里文件读写和使用XML和Json序列化
一.文件读写 1.基本操作(使用FileIO API) 这个方法在上一个stduy已经学过,那么贴出来复习下,代码如下: private async void writeTextToLocalStor ...
- POJ 3207 2-sat
题目大意: 在圆上顺时针n个点,给定m个连接,可以通过圆内或者圆外相交,问能不能找到一种方式,使这些连接的边都不相交 这里很容易看出的是,这些边只有在圆外或者圆内两种连接方式,而且必须选择其中一种 所 ...
- xlistview的XML(头)xlistview_header
<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android=" ...