weweb是一个兼容小程序语法的前端框架,你能够用小程序的写法,来写web单面应用。若是你已经有小程序了,经过它你能够将你的小程序运行在浏览器中。在小程序大行其道的今天,它可让你的小程序代码获得最大限度的发挥,他具备如下优势:前端
该项目基于小程序开发者工具内置的小程序运行框架来实现的,咱们在仔细研究了小程序官方的底层框架后,实现了小程序运行在web端的service和view引擎,为了使[weweb]能适应web端的性能要求,相较小程序原生框架,主要有如下调整:node
开发方式能够直接套用你之前开发小程序的方式,不须要另外的学习成本,只是在小程序开发完后,经过下面介绍的二种运行方式,把小程序编译转换成相应的h5应用,而后把编译后的代码扔到服务器上就好了ios
安装:github
npm install weweb-cli -g
运行示例:web
#./demos/demo20170111/这是小程序的存放路径 weweb ./demos/demo20170111/
Options:npm
# clone [weweb]项目后安装依赖 npm i # 构建核心库: npm run build # 运行示例: ./bin/weweb ./demos/demo20170111/ # 压缩app代码:使用环境变量 NODE_ENV=production NODE_ENV=production ./bin/weweb demos/demo20170111 # 替换编译器:当默认编译出错时使用环境变量 DFT_CMP=true 可切换为微信开发者工具自带的编译器 DFT_CMP=true ./bin/weweb demos/demo20170111 # 环境变量能够组合使用 NODE_ENV=production DFT_CMP=true ./bin/weweb demos/demo20170111
demo小程序二维码以下:json
点此查看weweb编译后的h5在线演示
能够比较一下小程序和转换后生成的h5应用的差别
[demo源码]小程序
weweb默认使用咱们本身写的编译器对wxml和wxss进行编译,但目前编译器还处于试用阶段,有些case可能没测全,使用weweb过程当中若是发现一些异常状况,能够尝试切换成微信官方编译器,看看是不否能解决问题。出现相似问题欢迎你们给咱们提[issue]。咱们将尽快修正后端
# 切换成微信开发者工具自带的编译器:使用环境变量 DFT_CMP=true 以下: DFT_CMP=true ./bin/weweb demos/demo20170111
转换成H5后,会存在跨域访问接口及脱离微信环境带来的一些api没法支持的问题。咱们能够经过在小程序的app.json
文件中增长weweb
配置项来解决一些常见的问题:
loginUrl
项来设置调用wx.login
时跳转到的登陆页面/** * 此处的loginUrl地址必须是在app.json里注册了的小程序地址 */ "weweb":{ "loginUrl":"/page/H5login" } 当登陆成功后调用 wx.loginSuccess(); 这个api能够自动返回到来源页面 示例代码: success : function(rt){ if(rt.result){ var login = require("../../modules/login/index.js"); app.globalData.userInfo = rt.result; login.setLoginInfo(rt.result); wx.loginSuccess(); }else{ toast.show(self,rt.status.status_reason||'登陆失败'); } }
/** * 此处/remoteProxy是weweb自带server实现的一个代理接口 * 实际项目中请改为本身的真实代理地址。若是接口支持返回jsonp格式,则无需作此配置 */ "weweb":{ "requestProxy":"/remoteProxy" }