微信开发中WXML, wxs和JS的示例分析

介绍

小编给大家分享一下微信开发中WXML, wxs和JS的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获、下面让我们一起去了解一下吧!

使用开发工具模拟的和真机差异还是比较大的。也建议大家还是真机调试比较靠谱。

<强> 1。WXML (HTML)

1.1小程序的WXML没有HTML的宽容度那么高,单标签必需是/比;结尾的。不然会报错。

1.2官方推荐使用的基础标签& lt; view>是块标签,给了& lt; text>作为文本标签,但是使用其他标签比如p也是可以使用的,并且都是内联标签。并且wxml的解析器会把标签上的不在白名单上的属性都去掉,类,id,数据这些应该都在白名单内,但是href什么的是不会有的,所以如果你用传统的html的标签构建页面理论上也是可行的,不过这些都是内联标签,需要自行设定显示。

1.3滚动视图的scroll-top,左右滚动是可以修改滚动视图的滚动位置的。但是用户自己滚动了之后小程序并不会去改变scroll-top,左右滚动的赋值(并不是双向同步的)。如果这时使用setData去修改的话,scroll-top,左右滚动的赋值和上一次的值相同,小程序是不会运用这个修改的,所以表现就是设置没有生效。这时只能先设置一个其他值,再设置回去(这里还可以体现setData方法是同步的).scroll-view获取滚动位置,只能通过bindscroll的回调函数获取,所以需要取滚动位置的请自行预存好.scroll-view还是有webview的滚动的臭毛病,在居顶位置如果第一个动作是向下滚动的,会导致之后手怎么滑都滚不动,设置scroll-top不为0,设1个就好了。

1.4输入目前只支持文字居左,其他都是不行的(模拟器可以)。如果你做表,单建议把输入等表单元素都放在表单中,从触发提交时会返回内部所有表单元素的名称。不然只能绑定所有表单元素的改变事情来获取,甚是麻烦。

1.5只有,复选框组有改变事件,单个的复选框是没有的,如果你只有一个复选框,觉得外面套一个复选框组麻烦又不美观的话,可以用开关类型=癱heckbox"代替。(微信小程序应用号交流群563752274)

1.6地图组建目前直接在应用第一个页面加载会出现加载失败。需要在onLoad之后再加在。可以先天气:如果=癴alse"然后onLoad的之后改成真实就行了。

1.7地图,帆布像是在webview上面盖一个本地组件的感觉。它们是没法被溢出以及上面盖元素的,你可以认为z - index写多高都没法在他上面,所以不建议在页面上做弹层和蒙层.canvas无法放在滚动视图中滚动会定位在初始位置,如果你给画布上设置背景颜色的话,你会发现背景色块跟着滚了,图没滚。

<强> 2。wxs (CSS)

2.1 wxs和CSS很像,基本所有的CSS都支持,小程序还提供了rpx这个单位。一屏幕宽是750 rpx。推荐使用这个来作为布局。不过有一些细小的差别我下面会列出

2.2 wxs不支持大括号嵌套({{}}),所以关键帧,CSS动画就不可用了,不过过渡是可用的。

2.3目前测试引入字体也是不可用的,前面WXML中提到的内容看SVG也是没法使用的,所以图标目前只能用图的方式做了。

2.4 wxs中是不能引入本地资源的,只能使用线上资源(模拟器是可以,但是别信),可以使用base64。(微信小程序应用号交流群563752274)

2.5 wxs的规则是不支持集联的,所以不能身体.main{背景:# 000;}这么写。所以写起来还是比较费劲的。每个类都得很长,不然怕重名。不过支持。当前{颜色:红色;}这样的写法,支持之后,在伪类,但是不支持第一个孩子胎nth-child这类伪类。

2.6 app.wxss和每个页面的wxs的覆盖关系是:如果有同名规则的话,页面会覆盖应用的,不是合并是覆盖。

<强> 3。JS

3.1 JS的运行环境和视图的运行环境是隔离的JS只能通过事件获取时机和setData方法修改数据来改变观点。

3.2 JS目前有个很大的问题是无法获取到页面像素级的宽度高度,所有事件回调的单位都是像素级的而不是rpx的,但是又不知道当前rpx, px的转换关系。比如过你用帆布画的图。你都不知道边界在哪里,这个很蛋疼的。

3.3上面有说过setData方法如果上一个值和下一个值相同时,是不会触发观修改的(见1.3)

3.4使用导航跳转的时候可以使用变量的方式跟在相对地址上,onLoad事件会在入参中传入(会转化成对象),但是返回的时候没有一个官方给出的数据通讯机制。可以使用getApp()获取到全局对象,给上面加点东西,自行实现.navigate最多5个什么的就不说了。

微信开发中WXML, wxs和JS的示例分析