uniapp 开发微信小程序问题笔记
最近接手了一个小程序开发,从头开始。使用了 uniapp 搭建,以前没有做过小程序开发,着手看文档、查文档。一步一步完成了任务的开发。特此记录开发过程中的问题。
开发建议:
- 使用 HBuilderX 工具进行开发。通过工具创建项目
- 遇到原来的 vue 写法怎么不生效,别犹豫去看文档,可能就是不支持。
- 有时间熟读文档。
- 跨端最大的问题就是兼容性。
1. 不能采用全局注册的方式注册组件
通常在 components 目录会存放项目中共用的组件,然后暴露install,全局引用安装
// components/index.js
// 各种组件
import Page from "./page.vue";
//
const Components = [Page];
export default {
install: (app) => {
// 注册
Components.forEach((component) => app.component(component.name, component));
},
};
// 然后在 main.js 引用注册
import Vue from "vue";
import Component from "@/components";
// 注册 就可以全局使用了。
Vue.use(Component);
但是在 uniapp 中不生效,有两种方式实现组件注册:
1.1 导入到 main.js 中进行注册
所有的组件直接导入到 mian.js 中,通过 Vue 对象注册即可在其他页面中引用。
要注意的是,注册的组件名必须是字符串,不能是page.name
import Vue from "vue";
import Page from "@/components/page.vue";
Vue.component("page", page);
1.2 特有的 easycom 模式注册组件
只要符合components/组件名称/组件名称.vue 文件存储路径,则不需要手动注册,可直接引用组件。
而且这有助于打包时剔除掉没有使用到的组件。
那现在我们的功能组件存放路径改为components/page/page.vue ,即可全局使用。
也可以在pages.json 配置自定义设置,定义哪些匹配的组件。
{
"easycom": {
"autoscan": true,
"custom": {
// uni-ui 规则如下配置
"^uni-(.*)": "@dcloudio/uni-ui/lib/uni-$1/uni-$1.vue"
}
}
}
新加的组件注意清除缓存,重新运行生效。
2. 小程序真机调试包太大,无法上传,分包处理
由于开始项目,所有的 UI 设计图都放在了前端,导致编译后整个包大小超过了 4M。开发时并没有提示这个问题,准备真机测试时,提示无法上传。就去找解决方案。
在采用方案之前耗费了好多时间去手动删除一些不用的文件、删除不用的代码。再一看无济于事,看来代码并占不了多少。
2.1 将所有静态资源都存放到远程服务器上
2.2 采用分包的方式,将主包的体积降下来
分包的方式,刚开始的时候所有的文件都是放在pages下的,pages.jon中 也都配置在 pages中。
需要将初始加载无关的模块拆出来,同 pages 同级目录下。
|———————————————————————————————————— 项目
|—————————————— integral
|——————— rank
|——————— log
|——————— mall
|—————————————— pages
|——————— index
|——————— login
|——————— user
|—————————————— pages.json
在pages.jong 通过属性subPackages 配置分包编译。
root 为分包的主目录,pages 目录下的页面,path为相对路径。
{
"pages": [
{
"path": "pages/index/index",
"style": {
"navigationBarTitleText": "首页"
}
},
{
"path": "pages/login/login",
"style": {
"navigationBarTitleText": "登录"
}
}
// ...
],
"subPackages": [
{
"root": "integral",
"pages": [
{
"path": "rank/rank",
"style": {
"navigationBarTitleText": "排行榜"
}
}
// ...
]
}
]
}
然后重新运行,再次真机调试,没有此前的包过大的提示。顺利打开小程序。
分包之后,检查此前已写好的模块之间的跳转。页面路径已经变化,
可以通过预加载的方式帮助我们在进入某个页面时,由框架自动预下载可能需要的分包,提高后续页面进入的启动速度。
以下配置,帮助我们在进入首页后,加载全部的分包。也可以指定加载分包的某个页面,具体查看官网preloadrule
{
"preloadRule": {
"pages/index/index": {
"network": "all",
"packages": ["__APP__"]
}
}
}
3. 内置组件不能绑定 class 的问题
在使用扩展的 UI 组件,比如 uni-ui、uView 等给这些组件绑定 class 时,渲染并不能渲染成功。
只能在给他们包一层view 自定义 calss 。避免全局的样式污染。
4. 定位 API 调用,需要增加授权配置manifest.json
增加配置,允许小程序调用位置的权限接口。然后通过requiredPrivateInfos定义你需要哪些方法。
{
/* 小程序特有相关 */
"mp-weixin": {
// ...
"permission": {
"scope.userLocation": {
"desc": "请求获取地理信息"
}
},
"requiredPrivateInfos": [
"getLocation",
"chooseAddress",
"choosePoi",
"chooseLocation"
]
}
}
如果我们如果想在小程序中功能使用定位功能,则需要申请高德、腾讯或其他地图的 SDK ,通过拿到的经纬度查询详细地址信息。
uni.getLocation(options)获取当前地理位置。
不能获取到地址中文描述,只能拿到经纬度等其他参数,可以在通过第三方地图服务,获取详细的位置信息。
address 地址信息仅 APP 端支持。
uni.chooseLocation(options) 提供给用户选择位置信息
可以拿到经纬度、位置名称以及详细的 address 中文描述。
5. 主包不能引用分包的组件
通过分包后,降低了主包的大小。但也出现了一个问题就是主包不能复用分包的组件,很容易理解就是访问主包的页面时,分包还不一定加载。
6. 小程序不支持 $attrs \ $listeners
通过对组件进行二次封装、三次封装。底层组件定义的属性、事件如果每层都定义接收,就很麻烦,
在 vue 中,通过属性inheritAttrs: false 不然根元素承载这些属性、时间,然后通过$attrs \ $listeners 绑定到目标元素上。
<template>
<view class="dictionary-picker">
<data-picker v-bind="$attrs" v-on="$listeners"></data-picker>
</view>
</template>
<script>
export default {
inheritAttrs: false,
};
</script>
在 uniapp 中,则是不可以的。他没有 $attrs \ $listeners 这两个属性。
7. 不支持自定义双向绑定model
在 vue 中定义一个组件的输入、输出通过绑定值、然后监听抛出事件处理逻辑,
<script>
export default {
name:'data-picker',
model:{
prop:'value',
event:'change',
},
methods:{
handleChange(val){
this.$emit('change',val)
}
}
}
这样在调用组件时可通过v-model绑定。<data-picker v-model='value' />
在 uniapp 中,则是不可以的。 小程序不支持
8. 不能绑定给 style、class 对象
小程序端不支持绑定对象给 class、style
<template>
<view class="dictionary-picker">
<view :class="boxStyle"></view>
</view>
</template>
<script>
export default {
computed: {
boxStyle() {
return {
active: this.activeTab ? true : false,
};
},
},
};
</script>
这样是不行的,渲染后的元素节点显示 object 。 不通过计算属性,直接在属性上绑定逻辑。
<template>
<view class="dictionary-picker">
<view :class="[activeTab ? 'active' : '']"></view>
</view>
</template>
9. 适配 iphone 底部刘海
在需要适配的页面,元素增加样式。特有的变量safe-area-inset-bottom \ safe-area-inset-bottom
建议这种通用性设置,提供一个基础公共组件
page. 通过定义插槽nav \ header \ main \ footer插入内容。这是一些公共的样式就不用每个页面去设置。
.footer {
padding-bottom: 0;
// IOS <11.2
padding-bottom: constant(safe-area-inset-bottom);
// iso >11.2
padding-bottom: env(safe-area-inset-bottom);
// 安全距离设置后,一定要设置背景,不然滚动的内容在下方可以看到
background-color: #fff;
}
10. 一些全局的配置色彩,字号 注意单位、格式。
在配置pages.json的一些设置,颜色都是必须是十六进制颜色,不能是 rgb 或 rgba
globalStyle.navigationBarBackgroundColor导航栏背景颜色globalStyle.backgroundColor下拉显示出来的窗口的背景色tabBar.colortab 上的文字默认颜色tabBar.backgroundColortab 的背景色tabBar.fontSize文字默认大小tabBar.iconWidth图标默认宽度(高度等比例缩放)...
11. 自定义手机顶部的导航栏。
通常手机顶部信号、电量等一些状态占据手机的部分位子。想让这部分区域也融入到我们的程序中。
配置pages.jons
{
"globalStyle": {
"navigationStyle": "custom"
}
}
设置自定义导航样式,这样你的页面会以手机屏幕的最顶端开始。顶部标题、返回都需要自己去定义了。
12. 在视图中不能直接使用绑定在Vue.prototype上的全局变量
直接在视图使用Vue.prototype上的变量是访问不到的。向下面这样:
<template>
<view>
<img :src="$baseUrl + data.imgUrl" />
</view>
</template>
可以通过计算属性,或者提供一个变量值.
<template>
<view>
<img :src="avatarUrl" />
</view>
</template>
<script>
export default {
data() {
return {
//
data:{}
}
},
computed: {
avatarUrl() {
return this.$baseUrl + '/upload' + this.data.imgUrl;
}
},
13. 二次封装 uni-ui 组件,更改的组件样式未生效。
微信小程序里的组件之间的样式隔离,只需要增加选项配置,
<script>
export default {
name: 'confirmDialog',
options: {
styleIsolation: 'shared' // 解除样式隔离
},
}
14. 使用微信小程序插件 plugin
主要是小程序插件 plugin 的开发文档,在manifest.json 中配置
{
"mp-weixin": {
"appid": "",
"usingComponents": true,
"plugins": {
"myPlugin": {
"version": "版本号",
"provider": "wx8**********75"
}
}
}
}
14.1 在这边引入的插件可全局引用,在需要引入的页面中配置,pages.json
{
"pages": [
{
"path": "pages/login/login",
"style": {
"navigationBarTitleText": "登录",
"enablePullDownRefresh": false,
// 定义微信插件
"mp-weixin": {
"usingComponents": {
"login": "plugin://myPlugin/login"
}
}
}
}
]
}
然后在页面 login.vue 中使用组件
<template>
<view class="login-box">
<login
:config="loginConfig"
></login>
</template>
14.2 分包引入插件,只能在分包中使用
在pages.json配置,同一个插件不能被多个分包引入,直接放入主包中配置。
{
"subPackages": [
{
"root": "integral",
"pages": [
{
"path": "integralMall/list"
}
],
"plugins": {
"pluginName": {
"version": "版本号",
"provider": "wx8**********75"
}
}
}
]
}
15. 拦截器uni.addInterceptor(API,Options)
对于 uni 可调用的全局 API,可通过拦截器来批量处理逻辑,常用就是拦截请求,控制权限。
在App.vue 中调用拦截,定义拦截器在未注册时控制某些页面不可访问。
import { Not_register_access_page } from "@/utils/config.js";
export default {
onLaunch: function () {
// 跳转拦截
uni.addInterceptor("navigateTo", {
invoke(config) {
if (
!$this.isRegister &&
!Not_register_access_page.includes(config.url)
) {
// 不允许访问,则将前置访问的page地址置空
config.url = "";
}
},
});
},
};
拦截器options参数
invoke拦截前触发success成功回调触发fail失败回调触发complete完成回调后触发
uni.removeInterceptor(API)删除拦截器
uniapp 开发微信小程序问题笔记的更多相关文章
- 使用uni-app开发微信小程序
uni-app 开发微信小程序 前言 9月份,开始开发微信小程序,也曾调研过wepy/mpvue,考虑到后期跨端的需求,最终选择使用了uni-app,本文主要介绍如何使用uni-app搭建小程序项目, ...
- uni-app开发微信小程序引入UI组件库(Vant-weapp)步骤
uni-app开发微信小程序引入UI组件库(Vant-weapp)步骤 这里以vant-weapp为例 uni-app官方文档介绍引入组件的方法 1. 新建相关目录 根目录下创建 wxcomponen ...
- 使用uView UI+UniApp开发微信小程序
在前面随笔的介绍中,我们已经为各种框架,已经准备了Web API.Winform端.Bootstrap-Vue的公司动态网站前端.Vue&Element的管理前端等内容,基本都是基于Web A ...
- 使用uView UI+UniApp开发微信小程序--判断用户是否登录并跳转
在<使用uView UI+UniApp开发微信小程序>的随笔中,介绍了基于uView UI+UniApp开发微信小程序的一些基础知识和准备工作,其中也大概介绍了一下基本的登录过程,本篇随笔 ...
- 使用uView UI+UniApp开发微信小程序--微信授权绑定和一键登录系统
在前面随笔<使用uView UI+UniApp开发微信小程序>和<使用uView UI+UniApp开发微信小程序--判断用户是否登录并跳转>介绍了微信小程序的常规登录处理和验 ...
- 使用uni-app开发微信小程序之登录模块
从微信小程序官方发布的公告中我们可获知:小程序体验版.开发版调用 wx.getUserInfo 接口,将无法弹出授权询问框,默认调用失败,需使用 <button open-type=" ...
- uni-app开发微信小程序的几天时间
人只有在不断的学习,才能不断的给自己充电,如果我们停止了学习,就像人没有了血脉,就会死亡,近来学习比较忙,压力比较大,整天面对着电脑,敲击代码,从中虽然收获了快乐,但是换来的确实身体的伤痛,最近虽然自 ...
- uniapp开发微信小程序跳转出现navigateTo:fail page "pages/user/pages/user/address/address" is not found
在app.json文件中pages中: ,{ "path" : "pages/user/address/address", "style" ...
- 微信小程序入门笔记-开通云开发(3)
1.介绍 开发者可以使用云开发开发微信小程序.小游戏,无需搭建服务器,即可使用云端能力. 云开发为开发者提供完整的原生云端支持和微信服务支持,弱化后端和运维概念,无需搭建服务器,使用平台提供的 API ...
- 基于uni-app的微信小程序之分包
作者:故事我忘了¢个人微信公众号:程序猿的月光宝盒 目录 0. 缘由 1. 关于分包 1.0 这是 官方文档 1.1 注意事项 2.使用方法 2.1 首先你得有个uniapp的微信小程序项目 2.2 ...
随机推荐
- Vue学习之--------Vue中过滤器(filters)的使用(代码实现)(2022/7/18)
1.过滤器 1.1 概念 过滤器: 定义:对要显示的数据进行特定格式化后再显示(适用于一些简单逻辑的处理). 语法: 1.注册过滤器:Vue.filter(name,callback) 或 new V ...
- 齐博x1注意事项:再强调严禁用记事本改任何文件
提醒大家,X1任何文件,不要用记事本修改.比如这个用户就改出问题了 导致后台不能升级. 当然这是问题之一, 还有其它意料之外的问题.还没发现. 这个用户做一个测试风格. 配置文件可能是用记事本修改的. ...
- [WPF] 抄抄超强的苹果官网滚动文字特效实现
1. 前言 今天 ChokCoco 大佬发布了一篇博客 超强的苹果官网滚动文字特效实现,iPhone 我是买不起的,但不妨碍我对抄特效感兴趣,正好我这周安排的工作已经完成了,于是有空练练手实现了一个 ...
- 4.可视化API
模式视图(可浏览api界面) #导包 依赖coreapi from rest_framework.schemas import get_schema_view # 将get_schema_view视图 ...
- pta第一次博客
目录 pta第一次博客 1.前言 2.设计与分析 第二次作业第二题 第三次作业第一题 第三次作业第二题 第三次作业第三题 3.踩坑心得: 4.改进建议 5.总结 pta第一次博客 1.前言 这三次pt ...
- Abp.Zero 手机号免密登录验证与号码绑定功能的实现(一):验证码模块
这是一篇系列博文,我将使用Abp.Zero搭建一套集成手机号免密登录验证与号码绑定功能的用户系统: Abp.Zero 手机号免密登录验证与号码绑定功能的实现(一):验证码模块 Abp.Zero 手机号 ...
- MySQL的下载、安装、配置
下载 官方下载地址:下载地址: 找到免费社区版本 进入到下面页面的时候,下载对应的MySQL,我这里选择Windows. 点击Download ,如下图: 后面他会提示你登录注册啥的,我们选择不需要, ...
- 论文笔记 - Fantastically Ordered Prompts and Where to Find Them: Overcoming Few-Shot Prompt Order Sensitivity
prompt 的影响因素 Motivation Prompt 中 Example 的排列顺序对模型性能有较大影响(即使已经校准参见好的情况下,选取不同的排列顺序依然会有很大的方差): 校准可以大幅度提 ...
- 畅联云平台(www.24hlink.cn)支持的用传列表
无锡蓝天 沈阳君丰 无锡富贝 海康威视 海湾 苏州思迪 法安通 北大青鸟 金盾 依爱 威隆 1)几乎集齐了市场上常见的用户信息传输装置的类型,如果没接入的,我们也能接入哦. 2)欢迎咨询我们关于用传的 ...
- RocketMQ 在同程旅行的落地实践
本文作者:刘树东 - 同程艺龙技术专家 01/使用概况 同程旅行选择RocketMQ主要基于以下几个方面的考虑: 技术栈:公司主要以 Java 开发为主,因此我们倾向于选择一款用 Java 实现的MQ ...