一次微信小程序的快速开发体验

起因

事情是这样的

一天早上组里还早激烈的讨论某个项目的可用性和发展前景,突然老大说了句,能不能做个小程序的版本呢?然后大家纷纷讨论起来,有反对有支持,我就说了一句,刚出来的时候搞过一会。。。然后就把我推出来了(日了狗了~~)

这个项目大概一个星期之后就要推出去了,换句话说,我要一个星期内搞个小程序的版本出来,宝宝有点慌了~~

不过既然接手了还是要好好做的,首先的,完全自己搞肯定是来不及,项目的模块绝对要复用起来,思索下大概有3点需要搞

  • HTML

  • CSS

  • javascript module

CSS

其中CSS在小程序的叫做WXSS,基本和CSS语法类似了,也就需要将标签选择器改了,比如

table{//XXX
}
//改成
.table{}

还有就是WXSS的尺寸单位比较推荐使用rpx,但是这里还是继续使用px,当然在响应式方面还需要自己改改,工程量不是很大

JS

对于JS方面就比较棘手了一点,唯一庆幸的是,原项目是用vue来做框架搭建的,仔细观察下小程序框架的语法结构,发现其实和vue很类似,都具备生命周期和各种事件绑定等等,所以在整体JS结构上面大概有几点需要修改

  • 生命周期函数

  created: function () {//xx}//改成onLoad: function() {}
  • 数据绑定

this.container = '';
//改成
this.setData({"container": ''
});

剩下的就是模块的引用,小程序本身也支持ES6语法,但还是有缺陷,比如不支持promise,可以通过引入相应的polyfill 来解决,还能顺便让小程序本身的API也应用上promise

//util.js
import Promise from './bluebird.min';
export const wxPromise = function(fn) {return function (obj = {}) {return new Promise((resolve, reject) => {obj.success = function(res) {resolve(res);}obj.fail = function(err) {reject(err);}fn(obj)})}
}

可以在需要调用的地方引入,或者直接在APP.js里面封装原API,然后挂载在全局上面

import {wxPromise} from '../../utils/util';
let login = wxPromise(wx.login);
let getUserInfo = wxPromise(wx.getUserInfo);
login().then((res) => {console.log(res);return getUserInfo();}).then((res) => {console.log(res);}).catch((res) => {console.log(res);})

原项目里面的模块还调用了window对象的属性,比如localstorage、innerWidth、innerHeight等等,在开发工具里面输出console.log(window)直接甩了我一个大大undefined,呵呵,都快崩溃了,后来想想,也不是完全没有办法,小程序也有类似的API来实现这些方法和属性,我要做的就是造一个window对象给它就可以了,老样子,直接挂载全局就行

App({window: {},location: {href: 'http://localhost/index.html?clear'},onLaunch: function() {let _this = this;getSystemInfo().then((res)=>{_this.window.innerWidth = res.windowWidth;_this.window.innerHeight = res.windowHeight;})_this.window.localStorage = {};_this.window.localStorage.setItem = wx.setStorageSync;_this.window.localStorage.getItem = wx.getStorageSync;_this.window.localStorage.clear = wx.removeStorageSync;}})
//注入到页面或者模块
let {window, location} = app;

HTML

最后一个难题就是HTML了,首先HTML直接套在WXML上面是行不通的,结果是可以编译显示出来,但是完全失去了HTML各个标签的意义,比如div块级标签所具备的属性都不存在了,当然你可以通过WXSS添加属性来兼容,比如

div, p {display:blcok
}

我个人并不赞同这种做法,因为在HTML中img、canvas等等并没有要求闭合标签,但是WXML是严格要求每个标签都要有闭合,就是说你想通过添加WXSS属性来兼容的话,首先要手动加img和canvas的闭合标签(在小程序中img标签应该是image,不然还是无法显示图片),其次就是怕官方下次更新迭代突然加入div这个组件,然后又要改版,烦~~
那么唯一的出路就是将HTML转成符合小程序的WXML出来,作为一个程序员,手动改也太掉价了。。。直接上工具,google查下,发现网上也有类似的工具出来,工具的转换原理是这样的话,首先HTML先转换成json对象,然后注入到模版,由模版生成。
但是有2个问题
1、转换出来的WXML是依赖模版渲染的,首先小程序的模版是不支持递归调用的,就是说,假如你的标签有6层嵌套的话,那么你需要复制6份模版出来,然后tmp1嵌套tmp2...temp6,这样的话你只能祈祷工具带来的模版有嵌套了足够多。
2、无法实现数据绑定,比如

<div>{{text}}</div>
//转换后原样输出了{{text}}
<view>{{text}}</view>

既然模版输出这条路走不通,那就只能借助node动态的输出WXML,思路和上面差不多,也是HTML生成json dom,然后递归渲染wxml节点,最后输出一份wxml文件,工具的实现在这里,细节就不多说了,目前还没有做canvas、audio、video标签的转换,有BUG的话直接提issue,最后求star

总结

没事别BB

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/282673.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

造数据时踏过的坑

1.在产生随机数时,在数据规模很大的时候很难出现自己要的模型,比如某个条件的数据量,此时要写一个方法,来造一批这样的数据 2.将控制数量,文件路径写成配置文件的形式,以免重复打包 3.输入输出文件夹,可以配置以免重复打包 转载于:https://www.cnblogs.com/rocky-AGE-24/p/7376…

如何证明 ConcurrentDictionary 字典操作不全是线程安全的

前言最近&#xff0c;看到一篇文章&#xff0c;讲到《ConcurrentDictionary字典操作竟然不全是线程安全的&#xff1f;》。首先&#xff0c;这个结论是正确的&#xff0c;但文中给出的一个证明例子&#xff0c;我觉得是有问题的。相关代码如下&#xff1a;using System.Collect…

微型计算机及接口技术试题,1月自考微型计算机及其接口技术试题及答案解析...

《1月自考微型计算机及其接口技术试题及答案解析》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《1月自考微型计算机及其接口技术试题及答案解析(11页珍藏版)》请在人人文库网上搜索。1、精品自学考试资料推荐全国 2018年 1月自考微型计算机及其接口技术试题课程代码…

16-djongo中间件学习

目录 前戏 我们在前面的课程中已经学会了给视图函数加装饰器来判断是用户是否登录&#xff0c;把没有登录的用户请求跳转到登录页面。我们通过给几个特定视图函数加装饰器实现了这个需求。但是以后添加的视图函数可能也需要加上装饰器&#xff0c;这样是不是稍微有点繁琐。 学完…

PHP基础(必须熟练掌握的基础)

<?php/*** 三元运算符的应用*/ /* $a 10; $b 15; echo $a > $b ? 1 : 0; */ // 注:php7新添加的运算符比较运算符x<>y // 如果x和y相等,就返回0,如果x>y,就返回1,如果x的值小于y,就返回-1/* $a "aaa"; $b "bbb"; echo $a.$b; *//*** …

子进程无法从标准输入读取数据

每个process对象最多只能调用一次start()方法&#xff0c;join([timeout])方法会阻塞调用process对象的进程&#xff0c;直到timeout时间超时&#xff0c;或者process进程退出。如果timeout设置为None&#xff0c;则无超时时间。对于linux操作系统的进程管理&#xff0c;父进程…

Eclipse控制项目的访问名称

Eclipse控制web项目的访问名称 web项目的访问路径&#xff08;名称&#xff09;修改 1.点击项目右键-》properties找到Context root 修改成我们需要的名字即可转载于:https://www.cnblogs.com/pypua/articles/7379950.html

计算机一级选择题已做完确认,计算机一级选择题(附答案)

点击蓝字关注我们(1)按照需求功能的不同&#xff0c;信息系统已形成各种层次&#xff0c;计算机应用于管理是开始于:()A)信息处理B)人事管理C)决策支持D)事务处理正确答案&#xff1a;A解析&#xff1a;计算机用于管理&#xff0c;起源于计算机在办公应用中对大量信息、数据的处…

参加51CTO培训,PMP考试通过啦

为什么选择考PMP&#xff1f;先介绍下自己的情况&#xff0c;毕业三年&#xff0c;单位类似于平台&#xff0c;不做技术&#xff0c;常态的工作是文案、商务、市场都会涉及些&#xff0c;对未来也有些迷茫。受前辈点拨可以学一些通用的技能&#xff0c;于是我选择了PMP&#xf…

如何查看服务器并发请求连接数

https://wenku.baidu.com/view/fb553d795acfa1c7aa00cc27?pcf2#1 转载于:https://www.cnblogs.com/linewman/p/9918760.html

C# 二十年语法变迁之 C# 5 和 C# 6参考

C# 二十年语法变迁之 C# 5 和 C# 6参考https://benbowen.blog/post/two_decades_of_csharp_ii/自从 C# 于 2000 年推出以来&#xff0c;该语言的规模已经大大增加&#xff0c;我不确定任何人是否有可能在任何时候都对每一种语言特性都有深入的了解。因此&#xff0c;我想写一系…

非涉密计算机检查的通知,关于开展非涉密计算机及可移动存储介质专项清理活动的紧急通知...

关于在全校范围内开展非涉密计算机及可移动存储介质专项清理活动的紧急通知密办字[2009]01号各单位&#xff1a;为有效遏制木马病毒和恶意代码的蔓延趋势&#xff0c;现在校内开展一次非涉密计算机及可移动存储介质的专项清理活动&#xff0c;要求如下&#xff1a;1、所有涉密人…

Spring Cloud构建微服务架构:服务消费(基础)

使用LoadBalancerClient在Spring Cloud Commons中提供了大量的与服务治理相关的抽象接口&#xff0c;包括DiscoveryClient、这里我们即将介绍的LoadBalancerClient等。对于这些接口的定义我们在上一篇介绍服务注册与发现时已经说过&#xff0c;Spring Cloud做这一层抽象&#x…

oracle数据库中VARCHAR2(50 CHAR) 和VARCHAR2(50) 有啥区别?

VARCHAR2&#xff08;50 char&#xff09;这种类型的字段最多放50个字符&#xff0c;不够50个用空格填充&#xff1b;而VARCHAR2(50)最大允许存放50个字符&#xff0c;但是不足50个也不用空格填充。varchar2是变长字符串&#xff0c;与CHAR类型不同&#xff0c;它不会使用空格填…

《解密小米之互联网下的商业奇迹》

解密小米《解密小米之互联网下的商业奇迹》 磐石之心 清华大学出版社 2014/10/1 书籍&#xff1a;《非同凡响想,乔布斯启示录》 磐石之心&#xff1a;原名王斌&#xff0c;互联网IT资深预言家&#xff0c;第一个提出互联网未来竞争是在线生活方式的竞争&#xff1b;第一个提出3…

计算机内存的故障,计算机内存出现故障的解决方法

内存如果出现故障&#xff0c;会造成系统运行不稳定、程序异常出错和*作系统无法安装的故障&#xff0c;下面将列举内存常见的故障排除实例。1)内存顺序引起的计算机工作不正常故障现象&#xff1a;一台p4计算机&#xff0c;使用的是华硕intel850芯片组的主板&#xff0c;两条r…

2018暑假集训---递推递归----一只小蜜蜂hdu2044

一只小蜜蜂... Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 93249 Accepted Submission(s): 33187Problem Description 有一只经过训练的蜜蜂只能爬向右侧相邻的蜂房&#xff0c;不能反向爬行。请编程计算蜜…

《ASP.NET Core 6框架揭秘》实例演示[28]:自定义一个服务器

作为ASP.NET Core请求处理管道的“龙头”的服务器负责监听和接收请求并最终完成对请求的响应。它将原始的请求上下文描述为相应的特性&#xff08;Feature&#xff09;&#xff0c;并以此将HttpContext上下文创建出来&#xff0c;中间件针对HttpContext上下文的所有操作将借助于…

高清摄像头MIPI接口与ARM连接【转】

本文转载自&#xff1a;http://www.cnblogs.com/whw19818/p/5811299.html MIPI摄像头常见于手机、平板中&#xff0c;支持500万像素以上高清分辨率。它的全称为“Mobile Industry Processor Interface”&#xff0c;分为MIPI DSI 和MIPI CSI&#xff0c;分别对应于视频显示和视…

算法(第4版)Robert Sedgewick 刷题 第一章(1)

/*** Description 颠倒数组排列顺序* author SEELE* date 2017年8月17日 上午10:56:17* action sortArr*/public static void sortArr() {int[] b new int[6];int[] a { 1, 2, 3, 4, 5, 6, 7 };for (int i 0; i < a.length / 2; i) {int temp a[a.length - 1 - i];a[a.l…