零基础入门uniapp Vue3组合式API版本到咸虾米壁纸项目实战,开发打包微信小程序、抖音小程序、H5、安卓APP客户端等
总时长 23:40:00 共116P
此文章包含第41p-第p51的内容
文章目录
-
- mainifest.json文件配置
- vue.config.js和vite.config.js
- 弹窗API
-
- [showToast 消息提示框](#showToast 消息提示框)
-
- [字多的时候 小程序需要把icon设置成none才可以自动换行,否则最多7个字](#字多的时候 小程序需要把icon设置成none才可以自动换行,否则最多7个字)
- 可以自定义图标
- [mask为true的时候 会阻止其他操作 等提示框消失后才可以操作](#mask为true的时候 会阻止其他操作 等提示框消失后才可以操作)
- 可以设置成功、失败、无论成败后都会调用的方法
- 可以快速隐藏
- 跳转tabBar页面
- [showLoading 加载框](#showLoading 加载框)
- [showModal m模态提示框](#showModal m模态提示框)
-
- 颜色样式文字
- [可以打开输入框 可以用于输入验证码等信息](#可以打开输入框 可以用于输入验证码等信息)
- showActionSheet底部弹出菜单
- [setNavigationBarTitle 动态设置当前页面标题](#setNavigationBarTitle 动态设置当前页面标题)
- [hideHomeButton 隐藏返回首页按钮](#hideHomeButton 隐藏返回首页按钮)
- [setTabBarBadge 设置tabBar角标](#setTabBarBadge 设置tabBar角标)
- [removeTabBarBadge 删除tabBar的角标](#removeTabBarBadge 删除tabBar的角标)
- [showTabBarRedDot 设置tabBar红点](#showTabBarRedDot 设置tabBar红点)
- [hideTabBarRedDot 隐藏tabBar红点](#hideTabBarRedDot 隐藏tabBar红点)
- onPullDownRefresh下拉刷新处理函数
- 页面和路由API
-
- [1. 使用navigator标签跳转](#1. 使用navigator标签跳转)
- [2. 使用js代码块进行跳转](#2. 使用js代码块进行跳转)
-
- [tabBar页面无法直接跳转 需要改成 reLaunch](#tabBar页面无法直接跳转 需要改成 reLaunch)
- [返回上一页 navigateBack](#返回上一页 navigateBack)
- 数据缓存API
-
- [setStorage 缓存数据到本地 setStorageSync 同步缓存数据到本地](#setStorage 缓存数据到本地 setStorageSync 同步缓存数据到本地)
- [getStorage 得到缓存数据到本地 getStorageSync 同步得到缓存数据到本地](#getStorage 得到缓存数据到本地 getStorageSync 同步得到缓存数据到本地)
-
- getStorageInfoSync打印全部的storage的key
- [removeStorageSync 删除某个缓存](#removeStorageSync 删除某个缓存)
- clearStorageSync清除所有缓存
mainifest.json文件配置
data:image/s3,"s3://crabby-images/9121b/9121b3a5b5f07d33f23b1e3dc4178f4d05c26a4a" alt=""
data:image/s3,"s3://crabby-images/9d867/9d867b5cc2aab64d86a9218a6210774bf8f6cecf" alt=""
获取微信小程序appid
在微信小程序里需要设置appid才可以使用预览和真机调试等功能
data:image/s3,"s3://crabby-images/515c2/515c214cc8c05d4855fa94896f5dcb52b74361de" alt=""
data:image/s3,"s3://crabby-images/b3460/b3460d86e83883abcdfc36d4077d8ff1d32314a2" alt=""
这个appid需要去微信公众平台进行获取
注册微信小程序
个人和企业都可以进行注册
ps:邮箱如果注册过公众号是无法注册小程序的 需要换一个(同一个邮箱取别名可以再次注册)
微信小程序控制台
注册完成后
data:image/s3,"s3://crabby-images/63d79/63d79706c56c9af9b70fc220adce3b383af80a2d" alt=""
data:image/s3,"s3://crabby-images/7a78e/7a78eeba856a45af2cb17d3c8c0afc46d666a092" alt=""
可以添加成员 添加后 这个人可以使用这个appid
这里勾选 使用代码压缩,因为小程序最多不能超过2MB
data:image/s3,"s3://crabby-images/02fa6/02fa6d57b65635e4de896208c231e141633b3241" alt=""
data:image/s3,"s3://crabby-images/8231f/8231fa34da057d0a92547af8633e27e069b95a9f" alt=""
图形界面和源码界面可以相互影响
data:image/s3,"s3://crabby-images/b9d65/b9d6563fca7d90c4478191df111ea0f59084025d" alt=""
data:image/s3,"s3://crabby-images/b00af/b00af889e990f91c36f5e4f25eaebbbf62007113" alt=""
vue.config.js和vite.config.js
data:image/s3,"s3://crabby-images/d5f1d/d5f1d58d00c040ea471fcdab2de65f084b1657c4" alt=""
这里我们使用vue3 所以我们使用vite.config.js
(vite编译速度比webpack要快。webpack让项目完整编译后才运行。vite运行那个页面,就编译那个页面。vite类似路由里面的懒加载)
使用vite.config.js 可以同一管理 vue的组件和uniapp的组件,每个页面引入的这个删掉进行同一管理
实现vue模块的自动导入
引用链接:
开发uniapp使用Vue3组合式API版本,如何实现从vue模块中自动导入
如果没安装过nodejs 需要下载并安装nodejs才可以使用npm命令
安装完以后运行命令
使用命令行窗口打开目录
data:image/s3,"s3://crabby-images/94448/94448b3c63aec2e2be13908e5db28f54be76c0dd" alt=""
多出一个文件夹
创建一个新文件vite.config.js
data:image/s3,"s3://crabby-images/89b05/89b05a64f34bfd6607238ba08cf2ac905d5506db" alt=""
自动导入模块AutoImport(个人不建议使用这个插件。还是在页面里引用import比较好)
命令npm i
可以自动导入需要的一些包
弹窗API
data:image/s3,"s3://crabby-images/eb242/eb242482aada4784258b2dc6630e17d6469561b0" alt=""
showToast 消息提示框
效果
data:image/s3,"s3://crabby-images/c492a/c492a97eec69b69d1b1474d77f85dd1ccd0338b8" alt=""
data:image/s3,"s3://crabby-images/4b982/4b982bc84f8d4d8fbf66f1d8c7044cfaa2281732" alt=""
data:image/s3,"s3://crabby-images/3b043/3b043d6fa0442989f63377d2d98f9655ca9b614b" alt=""
字多的时候 小程序需要把icon设置成none才可以自动换行,否则最多7个字
data:image/s3,"s3://crabby-images/a3174/a31748835498756075f1b7d401d1595db433a58e" alt=""
可以自定义图标
data:image/s3,"s3://crabby-images/b4ff0/b4ff07b02b292238a30188e34c657c46d84d11e5" alt=""
data:image/s3,"s3://crabby-images/46e2c/46e2ccf2f7a51a6e7ad0637b6460ae382ef202d8" alt=""
mask为true的时候 会阻止其他操作 等提示框消失后才可以操作
data:image/s3,"s3://crabby-images/96e25/96e252f836871f0b9b6b7eb01bab0da99fbfac3e" alt=""
可以设置成功、失败、无论成败后都会调用的方法
data:image/s3,"s3://crabby-images/e59f2/e59f2abfb7d60ded00c8568eed62a212635d6fbf" alt=""
data:image/s3,"s3://crabby-images/b2919/b2919563c387a329589d8fd23986e1713f901caf" alt=""
可以快速隐藏
data:image/s3,"s3://crabby-images/e5d66/e5d6652b832a1b719b27cf8834cca9e102ff52ba" alt=""
跳转tabBar页面
不可以直接使用navigateTo
可以使用reLaunch跳转
showLoading 加载框
data:image/s3,"s3://crabby-images/6d180/6d180b0164327c5c5661e309c2c9db1c719d1ebb" alt=""
加载中的时候 不可以操作后面的东西 所以mask为true
data:image/s3,"s3://crabby-images/fa2ef/fa2efb949e35879948076a6e88b66879ce3bb0f4" alt=""
隐藏loading
失败的时候 在请求那里也可以设置隐藏
showModal m模态提示框
data:image/s3,"s3://crabby-images/64dcf/64dcf141e46e158c54797cd27dd8137b8ad5206d" alt=""
data:image/s3,"s3://crabby-images/cfd79/cfd7992b6f84029f841ccc010237786bef60b6e7" alt=""
data:image/s3,"s3://crabby-images/88ab1/88ab11b3e5d915aea162001ca8ae8225e94fcca0" alt=""
颜色样式文字
data:image/s3,"s3://crabby-images/de0df/de0df058b4d931218525a2fd2a6549686db8fd8c" alt=""
data:image/s3,"s3://crabby-images/718b2/718b2611eb0bce9eb27bd7242780fc618d6dadfc" alt=""
data:image/s3,"s3://crabby-images/9f45d/9f45d75c10aa9e2ceb8399ab4a4cb232d6b6211f" alt=""
data:image/s3,"s3://crabby-images/23d09/23d0983c83ba045bb4cc2b7efa06243f397096a7" alt=""
可以打开输入框 可以用于输入验证码等信息
data:image/s3,"s3://crabby-images/cdd78/cdd78810c5c38eef4c641de36fc0366b7aa73200" alt=""
data:image/s3,"s3://crabby-images/9f4ea/9f4ea9a0e5894d2a739024af72615f37b1906ae8" alt=""
showActionSheet底部弹出菜单
data:image/s3,"s3://crabby-images/c900d/c900d8fb1d2181b66b3898ab5035f030fb1185e7" alt=""
点击效果 返回的是索引值
data:image/s3,"s3://crabby-images/73ff0/73ff06cd8d2f5a630d2c7bb91d5e3a2be87e69a8" alt=""
data:image/s3,"s3://crabby-images/9f7b5/9f7b5078aeb95b3f8a7bc4d430cd345988ed3500" alt=""
data:image/s3,"s3://crabby-images/e4c41/e4c41e302f7009f3711b5f3ba69b6db658a211a3" alt=""
setNavigationBarTitle 动态设置当前页面标题
data:image/s3,"s3://crabby-images/57a1e/57a1eb5cb1195c1bb3359049bbf8a07ef241e54c" alt=""
页面切换的时候 标题也是变化的
data:image/s3,"s3://crabby-images/df9fb/df9fbb289dfe7c3147e25fd62d4358c6254b18f4" alt=""
data:image/s3,"s3://crabby-images/5d9a1/5d9a1e4afed872f5b9cec6c0f25593a459aed577" alt=""
可以在标题旁边添加loading 和隐藏loading
hideHomeButton 隐藏返回首页按钮
仅微信小程序和京东小程序支持
setTabBarBadge 设置tabBar角标
data:image/s3,"s3://crabby-images/07184/07184e2bbf060519d97a9a8c5fe698ec92a5f29a" alt=""
在App.vue的onLaunch里设置,这样是全局都可以看到
data:image/s3,"s3://crabby-images/5c453/5c45360fc7419f5e9278275485d859608eb12c92" alt=""
removeTabBarBadge 删除tabBar的角标
data:image/s3,"s3://crabby-images/05a23/05a235cb63993cc19ec71b373600e69c8029ca05" alt=""
showTabBarRedDot 设置tabBar红点
data:image/s3,"s3://crabby-images/1566f/1566f0d2ccf3a9dc64e4499ccc77527722789e68" alt=""
hideTabBarRedDot 隐藏tabBar红点
data:image/s3,"s3://crabby-images/3b95d/3b95d27ca48de807f76945682eace3a016443d7f" alt=""
onPullDownRefresh下拉刷新处理函数
data:image/s3,"s3://crabby-images/ee058/ee0586b5a433d092c9c0199a00a2f3b54e87d559" alt=""
data:image/s3,"s3://crabby-images/7a639/7a639f55a3879b6acbc492d51ddb280cd38e49df" alt=""
startPullDownTefresh
关闭下拉刷新
页面和路由API
跳转的两种方式,
1. 使用navigator标签跳转
data:image/s3,"s3://crabby-images/3bdb8/3bdb80664927743de439adfac938a92988aab0a0" alt=""
2. 使用js代码块进行跳转
data:image/s3,"s3://crabby-images/75d75/75d753135d0473f43923be1e1f8ac3f1e5f83384" alt=""
可以带参数
可以看到小程序的参数
onLoad里可以看到参数
tabBar页面无法直接跳转 需要改成 reLaunch
返回上一页 navigateBack
data:image/s3,"s3://crabby-images/591ef/591efed7b76b7b9b9942a811a7201dfb70c93050" alt=""
可以看到当前返回了几页
data:image/s3,"s3://crabby-images/5cb6b/5cb6b2dda9a811c6f86f651c9621e4e3a86c202d" alt=""
data:image/s3,"s3://crabby-images/f19e3/f19e3021c5e521beec371f75f5db15a394a673b4" alt=""
data:image/s3,"s3://crabby-images/0424d/0424d34bc35c0d172710ae799e2ebeb54930075f" alt=""
这里可以看出我们打开了两个页面
一个压在另一个
数据缓存API
setStorage 缓存数据到本地 setStorageSync 同步缓存数据到本地
data:image/s3,"s3://crabby-images/13078/13078155fc49f0587cf7ff1c386bd21300aeefc8" alt=""
这里的搜索记录就是前端的缓存
同步缓存 异步缓存
data:image/s3,"s3://crabby-images/7d1c2/7d1c215e563513a5810feb1de3222e0a148fe279" alt=""
异步容易回调地狱,这里我们使用同步
使用同步
小程序里查看
getStorage 得到缓存数据到本地 getStorageSync 同步得到缓存数据到本地
data:image/s3,"s3://crabby-images/7a5f3/7a5f3119cce4608c727770165a8a15c1a102fc04" alt=""
getStorageInfoSync打印全部的storage的key
data:image/s3,"s3://crabby-images/5435a/5435aabcc9ada0436b88a7f742d2f2967ff83411" alt=""
data:image/s3,"s3://crabby-images/c7ccb/c7ccb13e96365a18568cced2f9b025e7489153a6" alt=""
removeStorageSync 删除某个缓存
data:image/s3,"s3://crabby-images/2cd35/2cd3526aae5bd6e8e9208c1dc826e02a1312ef9e" alt=""
clearStorageSync清除所有缓存
data:image/s3,"s3://crabby-images/80080/80080837a5a9ad36b7d87f5cbd78e5bc50667075" alt=""