混合APP开发流程

混合APP开发流程


一、什么是混合APP?

通俗的介绍一下混合APP(Hybrid App)
混合APP是指web app,就是普通的web网页,外面套了一层原生的壳,相当于一个原生的壳里面有一个WebView网页

二、搭建框架

1.搭建vue基础框架

包括路由,vuex,i18n等
此次省略一万字。。。

2.rem自适应屏幕配置

rem和em的区别

rem是相对html的,而em是相对于使用em单位的元素的字体大小
代码如下(示例):

p{
	font-size:20px;
	padding:10em;// 这里的10em是相对与20px的,也就是20*10=200px
}

代码如下(示例):

//designWidth:设计稿的实际宽度值,需要根据实际设置
//maxWidth:制作稿的最大宽度值,需要根据实际设置
//这段js的最后面有两个参数记得要设置,一个为设计稿实际宽度,一个为制作稿最大宽度,例如设计稿为750,最大宽度为750,则为(750,750)
(function(designWidth, maxWidth) {
	var doc = document,
		win = window,
		docEl = doc.documentElement,
		remStyle = document.createElement("style"),
		tid;

	function refreshRem() {
		var width = docEl.getBoundingClientRect().width;
		maxWidth = maxWidth || 540;
		width>maxWidth && (width=maxWidth);
		var rem = width * 100 / designWidth;
		remStyle.innerHTML = 'html{font-size:' + rem + 'px;}';
	}

	if (docEl.firstElementChild) {
		docEl.firstElementChild.appendChild(remStyle);
	} else {
		var wrap = doc.createElement("div");
		wrap.appendChild(remStyle);
		doc.write(wrap.innerHTML);
		wrap = null;
	}
	//要等 wiewport 设置好后才能执行 refreshRem,不然 refreshRem 会执行2次;
	refreshRem();

	win.addEventListener("resize", function() {
		clearTimeout(tid); //防止执行两次
		tid = setTimeout(refreshRem, 300);
	}, false);

	win.addEventListener("pageshow", function(e) {
		if (e.persisted) { // 浏览器后退的时候重新计算
			clearTimeout(tid);
			tid = setTimeout(refreshRem, 300);
		}
	}, false);

	if (doc.readyState === "complete") {
		doc.body.style.fontSize = "12px";
	} else {
		doc.addEventListener("DOMContentLoaded", function() {
			doc.body.style.fontSize = "12px";
		}, false);
	}
})(360, 1024);

在main.js中直接引入这个js文件

//引入rem文件
import './assets/public/rem.js';

使用rem单位
在任何css预加载中都可以使用rem作为单位,例如:

font-size:0.18rem;// 只需要按设计稿中的尺寸/100就好,他会自动转换

三、HBuilder打包

我这边使用的是云打包,然后生成下载链接后,因为云打包的下载链接只能下载五次,所以我们直接把app下载下来放到服务器上,然后通过手写一个接口实现下载功能,就可以无限下载啦

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值