html标签
  • weex中没有标签的概念,html中标签对应于weex中的Components

  • weex 无<span> 、<p> ,用<text>替代。但是<text>内部不能嵌入组件

  • 在HTML中通常使用的 <img> 标签在 Weex 中不支持,应该使用<image>

  • 内容部分有滚动效果,使用<scroller>。使用css的overflow属性不能让内容滚动。

css语法
  • Weex 中只支持单个类名选择器,不支持关系选择器,也不支持属性选择器。

  • 样式默认是 scoped,即组件级别作用域。

  • 视窗的宽度是750px(width=device-width),设计稿给出的是375px,故写css px 的时候要用2倍

  • 布局,使用flexbox 布局

  • box-shadow 安卓不支持, 目前官方最新的weex版本支持,需客户端sdk升级

  • iOS 如果写外部阴影,ios 要加上一个background。

    box-shadow: 0px 0px 6px #cccccc;
    background: #ffffff;
  • native, DOM设置position: absolute时, 不支持top、 left百分比, 要用px 写死。

  • 支持自定义font-family, 但是不支持自提文件放在服务器端,一般放在客户端本地。

    把字体文件放在native的时候,注意下路径,本地资源都采用'local:// '的方式加载,但是android需要加一个path,这个path随便填,如rpd。
  • 不支持z-index, 如果想要层级(如蒙层),请用position: absolute, 把你想要层级高的dom元素放在后边

  • 不支持css动画,要动画效果使用内建组件animation, 具体见https://weex-project.io/cn/references/modules/animation.html

  • border不支持简写。style、width、color只能分开写

关于DOM和BOM
  • weex环境中没有DOM,weex在native解析的html得到的是原生布局数

  • weex没有BOM,但是可以使用移动设备原生 API(即Modules),通过注册、调用模块来实现。

    例如const storage = weex.requireModule('storage');

vue语法
  • 事件修饰符 .prevent, .capture, .stop, .self在native不支持。键盘事件修饰符.enter, .tab, .ctrl, .shift同样在native也不支持。

  • 指令不支持 v-html 、v-show、v-clock

  • options 不支持comments

  • 实例方法不支持vm.$mount()

  • 内置组件不支持transition

  • 生命周期不支持activateddeactivated

  • 使用组件,直接绑定click.native ,在web端会触发两次,用事件传递(事件名称避免使用原生事件名称),可避免。

  • 组件事件传递,最好不要和原生事件冲突。比如子组件this.$emit('click'),在web端 父组件@click会响应两次,native却没有这个问题。

  • :class="['verifyitem--' + verifyStatus]”, class 写法不支持vue object的写法,只支持数组式的写法 , 而且只能写一个自定义的类。 由于 Weex 在 native 上的渲染机制,从类名中取样式会是一个高频操作,简化,具体见<https://github.com/alibaba/weex/issues/2303

  • input and switch 组件不支持 click事件,使用change or input 替代。

  • 不支持 document 和其他各种 DOM API。

  • 没有 windowscreenhistorylocationnavigator 等变量。

  • 关于蒙层, 安卓点透问题解决办法:e.preventDefault && e.preventDefault();

配置
  • 页面

src/entry.js 执行的始端,相当于项目模版中的index.js

src/views/a.js 页面a的配置,指定title和页面入口

src/entries/a/ 页面, 相当于项目模版中的src/webview/a

  • 代码在web端运行,需要依赖weex-vue-render(web端的vue DSL)。
  • 解析.vue文件需要的loader,native端需要 weex-loader , web端需要Webpack + vue-loader
调试
  • 本地运行的时候需要同时执行npm run dev 和 npm run serve

  • ios调试小工具->Week DebugTool->扫描二维码

    安卓调试小工具->功能->扫码

动态更新机制

目前,打开的weex页面的时候会向服务器请求js bundle,但是本次渲染的是本地的js bundle,要等到第二次打开才会渲染最新的。

这个更新机制不太友好,做不到h5的动态性。

其他
  • 区分端 weex.config.env.platform = web/iOS/android

  • 通过this.$route.push('/**') 打开另外一个weex页面,回到上一个页面的事件使用viewappear。具体见https://weex.apache.org/cn/references/common-event.html#Page-事件

  • ajax请求,如果是native端, 避免跨域

  • svg-icon 如果碰到显示不全,请用图片替代

一些参考的资料

weex h5开发区别-实践初级篇的更多相关文章

  1. 使用Asp.Net Core MVC 开发项目实践[第一篇:项目结构说明]

    先从下图看整体项目结构: Mango.Manager: 为后台管理项目 Mango.Web: 为前台项目 Mango.Framework.Core: 为常用的基础操作类项目 Mango.Framewo ...

  2. vivo浏览器的快速开发平台实践-总览篇

    一.什么是快速开发平台 快速开发平台,顾名思义就是可以使得开发更为快速的开发平台,是提高团队开发效率的生产力工具.近一两年,国内很多公司越来越注重研发效能的度量和提升,基于软件开发的特点,覆盖管理和优 ...

  3. 使用Asp.Net Core MVC 开发项目实践[第二篇:EF Core]

    在项目中使用EF Core还是比较容易的,在这里我们使用的版本是EF Core 2.2. 1.使用nuget获取EF Core包 这个示例项目使用的是SQLSERVER,所以还需要下载Microsof ...

  4. ABP框架实践基础篇之开发UI层

    返回总目录<一步一步使用ABP框架搭建正式项目系列教程> 说明 其实最开始写的,就是这个ABP框架实践基础篇.在写这篇博客之前,又回头复习了一下ABP框架的理论,如果你还没学习,请查看AB ...

  5. Python开发【第七篇】:面向对象 和 python面向对象(初级篇)(上)

    Python 面向对象(初级篇)   51CTO同步发布地址:http://3060674.blog.51cto.com/3050674/1689163 概述 面向过程:根据业务逻辑从上到下写垒代码 ...

  6. 【转帖】H5 手机 App 开发入门:概念篇

    H5 手机 App 开发入门:概念篇 http://www.ruanyifeng.com/blog/2019/12/hybrid-app-concepts.html 作者: 阮一峰 日期: 2019年 ...

  7. Hadoop MapReduce开发最佳实践(上篇)

    body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...

  8. 零基础学习hadoop到上手工作线路指导初级篇:hive及mapreduce

      此篇是在零基础学习hadoop到上手工作线路指导(初级篇)的基础,一个继续总结.五一假期:在写点内容,也算是总结.上面我们会了基本的编程,我们需要对hadoop有一个更深的理解:hadoop分为h ...

  9. Python开发【第七篇】:面向对象 和 python面向对象进阶篇(下)

    Python开发[第七篇]:面向对象   详见:<Python之路[第五篇]:面向对象及相关> python 面向对象(进阶篇)   上一篇<Python 面向对象(初级篇)> ...

随机推荐

  1. jenkins持续集成部署

    用到的技术和工具:git + maven + jdk + jenkins,首先服务器安装git.maven.jdk,这些都不再赘述. 1:开始安装主角jenkins,首先去官网下载war包(https ...

  2. python3 十六进制字符串进行分割并累加

    最近忘性大,记录一下 需求: ‘80 11 F1 01 1A’字符串需要把每一个十六进制字符加起来,即80+11+F1+01+1A=? 很简单,不解释,直接上 hex(sum([int(i,16) f ...

  3. jquery选择器问题(找东西超级有用)

    $("[class='slider-container theme-green']").css('width','100%');就这么一行代码,很简单,这样就很容易找到唯一元素

  4. K2项目开发流程

    (自己的学习资料) K2项目开发流程: 1.在VS2013中设计流程,并在K2 Workspce中测试流程 首先是新建新建一个k2的Process文件..kprx后缀. 在里面创建所需要的流程.由于我 ...

  5. 在Python脚本中调用Django环境

    import os if __name__ == '__main__': os.environ.setdefault("DJANGO_SETTINGS_MODULE", " ...

  6. python web编程之网络基础

    1.TCP/IP协议 1)分层 应用层,传输层,网络层,接口层 2)Ip地址 3)域名 4)URL统一资源定位符 格式:    [协议]://[主机]:[端口]/[路径]?[参数] 协议是HTTP,F ...

  7. VUE 引入阿里图标库

    本身项目是VUE, Element-UI项目, 所以内置Element-UI图标库 地址如下, https://element.eleme.cn/#/zh-CN/component/icon 使用时: ...

  8. Fiddler手机抓包设置

    前提条件:1).电脑需要安装Fiddler2).测试手机需要支持Wifi3).测试手机与电脑需要同一网络4).所测APP需支持代理 三.设置Fiddler 1.(1)电脑端打开安装好的的fiddler ...

  9. C Mergeable Stack(list超好用)

    ZOJ  4016 list用法https://www.cnblogs.com/LLLAIH/p/10673068.html 一开始用普通的栈做,超内存,链表模拟栈也没写出来orz.补题发现list超 ...

  10. Android Spannable为同一TextView设直不同样式

    /** * UNICODE * <p> * 偶尔吃(1-2次/周) ( 中文破弧 * 经常吃(3-5次/周) ( 英文破弧 * * @param name * @return */ pri ...