让你轻松上手【uni-app】 旧城等待, 2023-02-27 12:27 29阅读 0赞 ## 目标 ## > uni-app 的基本使用 > 环境搭建 + 页面外观配置 > 组件的使用 > uni-app中样式学习 > 在uni-app中使用字体图标和开启scss > 数据绑定 > uni-app的生命周期 > uni-app 的上/下拉刷新 > uni-app 中的网络 > uni-app 的数据缓存 > 条件注释跨端兼容 > uni-app中的事件 > 导航跳转 > 组件创建和通讯,及组件的生命周期 > uni-app中使用uni-ui库 ## 1. uni-app ## 1. `uni-app`[uni-app][] 是一个使用 [Vue.js][] 开发`所有前端应用的框架`,开发者编写一套代码,可发布到iOS、Android、H5、以及各种小程序(微信/支付宝/百度/头条/QQ/钉钉)等多个平台。 2. 即使不跨端,`uni-app`同时也是更好的小程序开发框架。 ## 2. 环境搭建 ## 1. 安装编辑器HBuilderX [下载地址][Link 1] 2. HBuilderX是通用的前端开发工具,但为`uni-app`做了特别强化(可以快速搭建uni-app项目);下载App开发版,可开箱即用。 3. 安装微信开发者工具 [下载地址][Link 2] ## 3. 创建项目并运行 ## ##### 3.1 创建 uni-app 项目 ##### * 点击HbuilderX菜单栏文件>项目>新建 * 选择uni-app,填写项目名称,项目创建的目录 ##### 3.2 运行项目 ##### * 在菜单栏中点击运行,`运行到浏览器`,选择浏览器即可运行 * 在`微信开发者工具里运行`:进入hello-uniapp项目,点击工具栏的运行 -> 运行到小程序模拟器 -> 微信开发者工具,即可在微信开发者工具里面体验uni-app * `运行到手机或模拟器`:进入hello-uniapp项目,点击工具栏的运行 -> 运行到手机或模拟器 -> 选择调式的手机 **注意:** * 如果是`第一次`使用,需要`先配置小程序ide的相关路径`,才能运行成功(官方文档有[提示][Link 3]) * 微信开发者工具在设置中安全设置,`服务端口开启` ## 4. uni-app 项目目录和文件作用 ## 1. `pages.json` 文件用来对 uni-app `进行全局配置`,决定页面文件的路径、窗口样式、原生的导航栏、底部的原生tabbar 等 2. `manifest.json` 文件是`应用的配置文件`,用于指定应用的名称、图标、权限等。 3. `App.vue`是我们的`跟组件`,所有页面都是在`App.vue`下进行切换的,是页面入口文件,可以调用`应用的生命周期函数`。 4. `main.js`是我们的`项目入口文件`,主要作用是初始化`vue`实例并使用需要的插件。 5. `uni.scss`文件的用途是为了方便整体控制应用的风格。比如按钮颜色、边框风格,`uni.scss`文件里预置了一批scss变量预置。 6. `unpackage`就是打包目录,在这里有各个平台的打包文件 7. `pages`所有的页面存放目录 8. `static`静态资源目录,例如图片等 9. `components`组件存放目录(本地组件+下载的组件) ##### 为了实现多端兼容,综合考虑编译速度、运行性能等因素,`uni-app` 约定了如下开发规范: ##### * 页面文件遵循 [Vue 单文件组件 (SFC) 规范][Vue _ _SFC_] * 组件标签靠近小程序规范,详见[uni-app 组件规范][uni-app 1] * 接口能力(JS API)靠近微信小程序规范,但需将前缀 `wx` 替换为 `uni`,详见[uni-app接口规范][uni-app 2] * 数据绑定及事件处理同 `Vue.js` 规范,同时补充了App及页面的生命周期 * 为兼容多端运行,`建议使用flex布局`进行开发 ## 5. 全局配置和页面配置 ## ##### 5.1 通过globalStyle进行全局配置 ##### 用于设置`应用的状态栏、导航条、标题、窗口背景色`等。[详细文档][Link 4] <table> <thead> <tr> <th>属性</th> <th>类型</th> <th>默认值</th> <th>描述</th> </tr> </thead> <tbody> <tr> <td>navigationBarBackgroundColor</td> <td>HexColor</td> <td>#F7F7F7</td> <td>导航栏背景颜色(同状态栏背景色)</td> </tr> <tr> <td>navigationBarTextStyle</td> <td>String</td> <td>white</td> <td>导航栏标题颜色及状态栏前景颜色,仅支持 black/white</td> </tr> <tr> <td>navigationBarTitleText</td> <td>String</td> <td></td> <td>导航栏标题文字内容</td> </tr> <tr> <td>backgroundColor</td> <td>HexColor</td> <td>#ffffff</td> <td>窗口的背景色</td> </tr> <tr> <td>backgroundTextStyle</td> <td>String</td> <td>dark</td> <td>下拉 loading 的样式,仅支持 dark / light</td> </tr> <tr> <td>enablePullDownRefresh</td> <td>Boolean</td> <td>false</td> <td>是否开启下拉刷新,详见<a href="https://uniapp.dcloud.io/use?id=%e9%a1%b5%e9%9d%a2%e7%94%9f%e5%91%bd%e5%91%a8%e6%9c%9f" rel="nofollow">页面生命周期</a>。</td> </tr> <tr> <td>onReachBottomDistance</td> <td>Number</td> <td>50</td> <td>页面上拉触底事件触发时距页面底部距离,单位只支持px,详见<a href="https://uniapp.dcloud.io/use?id=%e9%a1%b5%e9%9d%a2%e7%94%9f%e5%91%bd%e5%91%a8%e6%9c%9f" rel="nofollow">页面生命周期</a></td> </tr> </tbody> </table> ##### 5.2 创建新的message页面(页面配置演示) ##### 右键pages新建message目录,在message目录下右键新建.vue文件,并选择基本模板 <template> <view> 这是信息页面 </view> </template> <script> </script> <style> </style> ##### 5.3 通过pages来配置页面 ##### <table> <thead> <tr> <th>属性</th> <th>类型</th> <th>默认值</th> <th>描述</th> </tr> </thead> <tbody> <tr> <td>path</td> <td>String</td> <td></td> <td>配置页面路径</td> </tr> <tr> <td>style</td> <td>Object</td> <td></td> <td>配置页面窗口表现,配置项参考 <a href="https://uniapp.dcloud.io/collocation/pages?id=style" rel="nofollow">pageStyle</a></td> </tr> </tbody> </table> pages数组数组中`第一项表示应用启动页` "pages": [ 、 { "path":"pages/message/message" }, { "path": "pages/index/index", "style": { "navigationBarTitleText": "uni-app" } } ] 通过style修改页面的标题和导航栏背景色,并且设置h5下拉刷新的特有样式 "pages": [ //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages { "path":"pages/message/message", "style": { "navigationBarBackgroundColor": "#007AFF", "navigationBarTextStyle": "white", "enablePullDownRefresh": true, "disableScroll": true, "h5": { "pullToRefresh": { "color": "#007AFF" } } } } ] ##### 5.4 配置tabbar ##### 如果应用是一个多 tab 应用,可以通过 tabBar 配置项指定 tab 栏的表现,以及 tab 切换时显示的对应页。 **Tips** * 当设置 position 为 top 时,将不会显示 icon * tabBar 中的 list 是一个数组,只能`配置最少2个、最多5个 tab`,tab 按数组的顺序排序。 **属性说明:** <table> <thead> <tr> <th>属性</th> <th>类型</th> <th>必填</th> <th>默认值</th> <th>描述</th> <th>平台差异说明</th> </tr> </thead> <tbody> <tr> <td>color</td> <td>HexColor</td> <td>是</td> <td></td> <td>tab 上的文字默认颜色</td> <td></td> </tr> <tr> <td>selectedColor</td> <td>HexColor</td> <td>是</td> <td></td> <td>tab 上的文字选中时的颜色</td> <td></td> </tr> <tr> <td>backgroundColor</td> <td>HexColor</td> <td>是</td> <td></td> <td>tab 的背景色</td> <td></td> </tr> <tr> <td>borderStyle</td> <td>String</td> <td>否</td> <td>black</td> <td>tabbar 上边框的颜色,仅支持 black/white</td> <td>App 2.3.4+ 支持其他颜色值</td> </tr> <tr> <td>list</td> <td>Array</td> <td>是</td> <td></td> <td>tab 的列表,详见 list 属性说明,最少2个、最多5个 tab</td> <td></td> </tr> <tr> <td>position</td> <td>String</td> <td>否</td> <td>bottom</td> <td>可选值 bottom、top</td> <td>top 值仅微信小程序支持</td> </tr> </tbody> </table> 其中 list 接收一个数组,数组中的每个项都是一个对象,其属性值如下: <table> <thead> <tr> <th>属性</th> <th>类型</th> <th>必填</th> <th>说明</th> </tr> </thead> <tbody> <tr> <td>pagePath</td> <td>String</td> <td>是</td> <td>页面路径,必须在 pages 中先定义</td> </tr> <tr> <td>text</td> <td>String</td> <td>是</td> <td>tab 上按钮文字,在 5+APP 和 H5 平台为非必填。例如中间可放一个没有文字的+号图标</td> </tr> <tr> <td>iconPath</td> <td>String</td> <td>否</td> <td>图片路径,icon 大小限制为40kb,建议尺寸为 81px * 81px,当 postion 为 top 时,此参数无效,不支持网络图片,不支持字体图标</td> </tr> <tr> <td>selectedIconPath</td> <td>String</td> <td>否</td> <td>选中时的图片路径,icon 大小限制为40kb,建议尺寸为 81px * 81px ,当 postion 为 top 时,此参数无效</td> </tr> </tbody> </table> 案例代码: "tabBar": { "list": [ { "text": "首页", "pagePath":"pages/index/index", "iconPath":"static/tabs/home.png", "selectedIconPath":"static/tabs/home-active.png" }, { "text": "信息", "pagePath":"pages/message/message", "iconPath":"static/tabs/message.png", "selectedIconPath":"static/tabs/message-active.png" }, { "text": "我们", "pagePath":"pages/contact/contact", "iconPath":"static/tabs/contact.png", "selectedIconPath":"static/tabs/contact-active.png" } ] } ##### 5.5 condition启动模式配置 ##### 启动模式配置,仅开发期间生效,用于模拟直达页面的场景,eg:小程序转发后,用户点击所打开的页面。 **属性说明:** <table> <thead> <tr> <th>属性</th> <th>类型</th> <th>是否必填</th> <th>描述</th> </tr> </thead> <tbody> <tr> <td>current</td> <td>Number</td> <td>是</td> <td>当前激活的模式,list节点的索引值</td> </tr> <tr> <td>list</td> <td>Array</td> <td>是</td> <td>启动模式列表</td> </tr> </tbody> </table> **list说明:** <table> <thead> <tr> <th>属性</th> <th>类型</th> <th>是否必填</th> <th>描述</th> </tr> </thead> <tbody> <tr> <td>name</td> <td>String</td> <td>是</td> <td>启动模式名称</td> </tr> <tr> <td>path</td> <td>String</td> <td>是</td> <td>启动页面路径</td> </tr> <tr> <td>query</td> <td>String</td> <td>否</td> <td>启动参数,可在页面的 <a href="https://uniapp.dcloud.io/use?id=%e9%a1%b5%e9%9d%a2%e7%94%9f%e5%91%bd%e5%91%a8%e6%9c%9f" rel="nofollow">onLoad</a> 函数里获得</td> </tr> </tbody> </table> ## 6. 组件的基本使用 ## `uni-app`提供了丰富的基础组件给开发者,开发者可以像搭积木一样,组合各种组件拼接称自己的应用 `uni-app`中的组件,就像 `HTML` 中的 `div` 、`p`、`span` 等标签的作用一样,用于搭建页面的基础结构 ##### 6.1 text文本组件的用法 ##### 1. text组件的属性 <table> <thead> <tr> <th align="center">属性</th> <th align="center">类型</th> <th align="center">默认值</th> <th align="center">必填</th> <th align="center">说明</th> </tr> </thead> <tbody> <tr> <td align="center">selectable</td> <td align="center">boolean</td> <td align="center">false</td> <td align="center">否</td> <td align="center">文本是否可选</td> </tr> <tr> <td align="center">space</td> <td align="center">string</td> <td align="center">.</td> <td align="center">否</td> <td align="center">显示连续空格,可选参数:<code>ensp</code>、<code>emsp</code>、<code>nbsp</code></td> </tr> <tr> <td align="center">decode</td> <td align="center">boolean</td> <td align="center">false</td> <td align="center">否</td> <td align="center">是否解码</td> </tr> </tbody> </table> * `text` 组件相当于行内标签、在同一行显示 * 除了文本节点以外的其他节点都无法长按选中 1. 代码示例 <view> <!-- 长按文本是否可选 --> <text selectable='true'>来了老弟</text> </view> <view> <!-- 显示连续空格的方式 --> <view> <text space='ensp'>来了 老弟</text> </view> <view> <text space='emsp'>来了 老弟</text> </view> <view> <text space='nbsp'>来了 老弟</text> </view> </view> <view> <text>skyblue</text> </view> <view> <!-- 是否解码 --> <text decode='true'> < > & ' </text> </view> ##### 6.2 view视图容器组件的用法 ##### View 视图容器, 类似于 HTML 中的 div 1. View 组件的属性 ![在这里插入图片描述][watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2N3cTUyMW8_size_16_color_FFFFFF_t_70] 1. 代码示例 <view class="box2" hover-class="box2_active"> <view class='box1' hover-class='active' hover-stop-propagation :hover-start-time="2000" :hover-stay-time='2000'> </view> </view> ##### 6.3 button按钮组件的用法 ##### 1. button 组件的属性 <table> <thead> <tr> <th align="center">属性名</th> <th align="center">类型</th> <th align="center">默认值</th> <th align="center">说明</th> </tr> </thead> <tbody> <tr> <td align="center">size</td> <td align="center">String</td> <td align="center">default</td> <td align="center">按钮的大小</td> </tr> <tr> <td align="center">type</td> <td align="center">String</td> <td align="center">default</td> <td align="center">按钮的样式类型</td> </tr> <tr> <td align="center">plain</td> <td align="center">Boolean</td> <td align="center">false</td> <td align="center">按钮是否镂空,背景色透明</td> </tr> <tr> <td align="center">disabled</td> <td align="center">Boolean</td> <td align="center">false</td> <td align="center">是否按钮</td> </tr> <tr> <td align="center">loading</td> <td align="center">Boolean</td> <td align="center">false</td> <td align="center">名称是否带 loading t图标</td> </tr> </tbody> </table> * `button` 组件默认独占一行,设置 `size` 为 `mini` 时可以在一行显示多个 1. 代码示例 <button size='mini' type='primary'>前端</button> <button size='mini' type='default' disabled='true'>前端</button> <button size='mini' type='warn' loading='true'>前端</button> ##### 6.4 image组件的使用 ##### 1. image 组件的属性 ![在这里插入图片描述][watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2N3cTUyMW8_size_16_color_FFFFFF_t_70 1] 1. 代码示例 <image src="../../static/images/1.jpg" mode="aspectFit"></image> **Tips** * `<image>` 组件默认宽度 300px、高度 225px(`但在不同设备中会有所差异`); * `src` 仅支持相对路径、绝对路径,支持 base64 码; * 页面结构复杂,css样式太多的情况,使用 image 可能导致样式生效较慢,出现 “闪一下” 的情况,此时设置 `image{will-change: transform}` ,可优化此问题。 ## 7. uni-app 中的样式 ## * `rpx` 即`响应式px`,一种根据屏幕宽度`自适应的动态单位`。以750宽的屏幕为基准,750rpx恰好为屏幕宽度。屏幕变宽,rpx 实际显示效果会等比放大。 * 使用`@import`语句可以导入外联样式表,`@import`后跟需要导入的外联样式表的相对路径,用`;`表示语句结束 * 支持基本常用的选择器class、id、element等 * 在 `uni-app` 中不能使用 `*` 选择器。 * `page` 相当于 `body` 节点 * 定义在 `App.vue 中的样式为全局样式`,作用于每一个页面。在 pages 目录下 的 `vue 文件中定义的样式为局部样式`,只作用在对应的页面,并会覆盖 App.vue 中相同的选择器。 * `uni-app` 支持使用字体图标,使用方式与普通 `web` 项目相同,需要注意以下几点: * 字体文件小于 40kb,`uni-app` 会自动将其转化为 base64 格式; * 字体文件大于等于 40kb, 需开发者自己转换,否则使用将不生效; * 字体文件的引用路径推荐使用以 ~@ 开头的绝对路径。 @font-face { font-family: test1-icon; src: url('~@/static/iconfont.ttf'); } * 若使用`scss或者less`(需要在HBuilderX 编辑器中下载对应插件),建议使用 `scss` 因为根目录下有 `uni.scss` 比较方便(对于已声明的变量) ## 8. uni-app 中的数据绑定 ## 在页面中需要定义数据,和vue一摸一样,直接在data中定义数据即可 export default { data () { return { msg: 'hello-uni' } } } ##### 8.1 插值表达式的使用 ##### * 利用插值表达式渲染基本数据 <view>{ {msg}}</view> * 在插值表达式中使用三元运算 <view>{ { flag ? '我是真的':'我是假的' }}</view> * 基本运算 <view>{ {1+1}}</view> ##### 8.2 v-bind动态绑定属性 ##### 在data中定义了一张图片,我们希望把这张图片渲染到页面上 export default { data () { return { img: 'http://destiny001.gitee.io/image/monkey_02.jpg' } } } 利用v-bind进行渲染 <image v-bind:src="img"></image> 还可以缩写成: <image :src="img"></image> ##### 8.3 v-for的使用 ##### data中定以一个数组,最终将数组渲染到页面上 data () { return { arr: [ { name: '刘能', age: 29 }, { name: '赵四', age: 39 }, { name: '宋小宝', age: 49 }, { name: '小沈阳', age: 59 } ] } } 利用v-for进行循环 <view v-for="(item,i) in arr" :key="i">名字:{ { item.name}}---年龄:{ { item.age}}</view> ## 9. uni-app 中的事件 ## ##### 9.1 事件绑定 ##### 在uni中事件绑定和vue中是一样的,通过v-on进行事件的绑定,也可以简写为@ <button @click="tapHandle">点我啊</button> 事件函数定义在methods中 methods: { tapHandle () { console.log('真的点我了') } } ##### 8.2 事件传参 ##### 默认如果没有传递参数,事件函数第一个形参为事件对象 // template <button @click="tapHandle">点我啊</button> // script methods: { tapHandle (e) { console.log(e) } } 如果给事件函数传递参数了,则对应的事件函数形参接收的则是传递过来的数据 // template <button @click="tapHandle(1)">点我啊</button> // script methods: { tapHandle (num) { console.log(num) } } 如果获取事件对象也想传递参数 // template <button @click="tapHandle(1,$event)">点我啊</button> // script methods: { tapHandle (num,e) { console.log(num,e) } } ## 10. uni的生命周期 ## ##### 10.1 应用的生命周期 ##### `生命周期的概念`:一个对象从创建、运行、销毁的整个过程被成为生命周期。 `生命周期函数`:在生命周期中每个阶段会伴随着每一个函数的触发,这些函数被称为生命周期函数 `uni-app` 支持如下`应用生命周期函数:` <table> <thead> <tr> <th>函数名</th> <th>说明</th> </tr> </thead> <tbody> <tr> <td>onLaunch</td> <td>当<code>uni-app</code> 初始化完成时触发(全局只触发一次)</td> </tr> <tr> <td>onShow</td> <td>当 <code>uni-app</code> 启动,或从后台进入前台显示</td> </tr> <tr> <td>onHide</td> <td>当 <code>uni-app</code> 从前台进入后台</td> </tr> <tr> <td>onError</td> <td>当 <code>uni-app</code> 报错时触发</td> </tr> </tbody> </table> ##### 10.2 页面的生命周期 ##### `uni-app` 支持如下页面生命周期函数: <table> <thead> <tr> <th>函数名</th> <th>说明</th> <th>平台差异说明</th> <th>最低版本</th> </tr> </thead> <tbody> <tr> <td>onLoad</td> <td>监听页面加载,其参数为上个页面传递的数据,参数类型为Object(用于页面传参),参考<a href="https://uniapp.dcloud.io/api/router?id=navigateto" rel="nofollow">示例</a></td> <td></td> <td></td> </tr> <tr> <td>onShow</td> <td>监听页面显示。页面每次出现在屏幕上都触发,包括从下级页面点返回露出当前页面</td> <td></td> <td></td> </tr> <tr> <td>onReady</td> <td>监听页面初次渲染完成。</td> <td></td> <td></td> </tr> <tr> <td>onHide</td> <td>监听页面隐藏</td> <td></td> <td></td> </tr> <tr> <td>onUnload</td> <td>监听页面卸载</td> <td></td> <td></td> </tr> </tbody> </table> #### 11. 下/上拉刷新 #### ##### 11.1 开启下拉刷新 ##### 在uni-app中有两种方式开启下拉刷新 * 首先需要在 `pages.json` 里,找到的当前页面的pages节点,并在 `style` 选项中开启 `enablePullDownRefresh` * 通过调用`uni.startPullDownRefresh`方法来开启下拉刷新 ###### 通过配置文件开启 ###### 创建list页面进行演示 <template> <view> 学习 <view v-for="(item,index) in arr" :key="index"> { {item}} </view> </view> </template> <script> export default { data () { return { arr: ['前端','java','ui','大数据'] } } } </script> <style> </style> 通过`pages.json`文件中找到当前页面的pages节点,并在 `style` 选项中开启 `enablePullDownRefresh` { "path":"pages/list/list", "style":{ "enablePullDownRefresh": true } } ###### 通过API开启 ###### [api文档][api] uni.startPullDownRefresh() ##### 监听下拉刷新 ##### 通过`onPullDownRefresh`可以监听到下拉刷新的动作 export default { data () { return { arr: ['前端','java','ui','大数据'] } }, methods: { startPull () { uni.startPullDownRefresh() } }, onPullDownRefresh () { console.log('触发下拉刷新了') } } ##### 关闭下拉刷新 ##### uni.stopPullDownRefresh() 案例演示 <template> <view> <button type="primary" @click="startPull">开启下拉刷新</button> 学习 <view v-for="(item,index) in arr" :key="index"> { {item}} </view> </view> </template> <script> export default { data () { return { arr: ['前端','java','ui','大数据'] } }, methods: { startPull () { uni.startPullDownRefresh() } }, onPullDownRefresh () { setTimeout(()=> { this.arr = ['前端','java','ui','大数据'] uni.stopPullDownRefresh() }, 1000); } } </script> ##### 11.2 上拉加载 ##### 通过在`pages.json`文件中找到当前页面的pages节点下style中配置`onReachBottomDistance`可以设置距离底部开启加载的距离,默认为50px;通过`onReachBottom`监听到触底的行为 <template> <view> <button type="primary" @click="startPull">开启下拉刷新</button> 杭州学科 <view v-for="(item,index) in arr" :key="index"> { { item}} </view> </view> </template> <script> export default { data () { return { arr: ['前端','java','ui','大数据','前端','java','ui','大数据'] } }, onReachBottom () { console.log('触底了') } } </script> <style> view{ height: 100px; line-height: 100px; } </style> ##### 11.3 综合案例 ##### <template> <view> <view>下拉刷新</view> <button @click="setStorage" type="default">存id</button> <button @click="getStorage" type="primary">取id</button> <button @click="removeStorage" type="warn">删id</button> <button type="default" @click="pullDown">点击触发下拉刷新</button> <view class="list_style" v-for="(item,index) in list" :key="index">{ { item}}</view> </view> </template> <script> export default{ data(){ return{ list:['web','java','python','大数据','人工智能','数据库'] } }, onPullDownRefresh(){ //下拉刷新 setTimeout(()=>{ this.list.push('php','mysql'); uni.stopPullDownRefresh(); },2000) }, onReachBottom(){ //上拉刷新 console.log('触底了,刷新数据'); this.list = [...this.list,...['web','java','python','大数据','人工智能','数据库']] }, methods:{ pullDown(){ uni.startPullDownRefresh() } } } </script> <style> .list_style{ height: 200px; line-height: 200px; } </style> ## 12. 网络请求 ## 在uni中可以调用uni.request方法进行请求网络请求 参数繁多:详见官网:[https://uniapp.dcloud.io/api/request/request?id=request][https_uniapp.dcloud.io_api_request_request_id_request] 需要注意的是:在`小程序`中网络相关的 API 在使用前`需要配置域名白名单`。 **演示发送get请求** <template> <view> <button @click="sendGet">发送请求</button> </view> </template> <script> export default { methods: { sendGet () { uni.request({ url: 'http://localhost:8082/comeon', success(res) { console.log(res) } }) } } } </script> ## 13. 数据缓存 ## ##### **uni.setStorage** ##### [官方文档][Link 5] 将数据存储在本地缓存中指定的 key 中,会覆盖掉原来该 key 对应的内容,这是一个`异步接口`。 代码演示 <template> <view> <button type="primary" @click="setStor">存储数据</button> </view> </template> <script> export default { methods: { setStor () { uni.setStorage({ key: 'id', data: 100, success () { console.log('存储成功') } }) } } } </script> <style> </style> ##### uni.setStorageSync ##### 将 data 存储在本地缓存中指定的 key 中,会覆盖掉原来该 key 对应的内容,这是一个`同步接口`。 代码演示 <template> <view> <button type="primary" @click="setStor">存储数据</button> </view> </template> <script> export default { methods: { setStor () { uni.setStorageSync('id',100) } } } </script> <style> </style> ##### uni.getStorage ##### 从本地缓存中异步获取指定 key 对应的内容。 代码演示 <template> <view> <button type="primary" @click="getStorage">获取数据</button> </view> </template> <script> export default { data () { return { id: '' } }, methods: { getStorage () { uni.getStorage({ key: 'id', success: res=>{ this.id = res.data } }) } } } </script> ##### uni.getStorageSync ##### 从本地缓存中同步获取指定 key 对应的内容。 代码演示 <template> <view> <button type="primary" @click="getStorage">获取数据</button> </view> </template> <script> export default { methods: { getStorage () { const id = uni.getStorageSync('id') console.log(id) } } } </script> ##### uni.removeStorage ##### 从本地缓存中异步移除指定 key。 代码演示 <template> <view> <button type="primary" @click="removeStorage">删除数据</button> </view> </template> <script> export default { methods: { removeStorage () { uni.removeStorage({ key: 'id', success: function () { console.log('删除成功') } }) } } } </script> ##### uni.removeStorageSync ##### 从本地缓存中同步移除指定 key。 代码演示 <template> <view> <button type="primary" @click="removeStorage">删除数据</button> </view> </template> <script> export default { methods: { removeStorage () { uni.removeStorageSync('id') } } } </script> ## 14. 上传图片、预览图片 ## [图片API][API] ##### 14.1 上传图片 ##### `uni.chooseImage`方法从本地相册选择图片或使用相机拍照。 代码示例 <template> <view> <button @click="chooseImg" type="primary">上传图片</button> <view> <image v-for="item in imgArr" :src="item" :key="index"></image> </view> </view> </template> <script> export default { data () { return { imgArr: [] } }, methods: { chooseImg () { uni.chooseImage({ count: 9, success: res=>{ this.imgArr = res.tempFilePaths } }) } } } </script> ##### 14.2 预览图片 ##### 代码示例 <view> <image v-for="item in imgArr" :src="item" @click="previewImg(item)" :key="item"></image> </view> 预览图片的方法 previewImg (current) { uni.previewImage({ urls: this.imgArr, current }) } ## 15. 条件注释实现跨端兼容 ## 条件编译是用特殊的注释作为标记,在编译时根据这些特殊的注释,将注释里面的代码编译到不同平台。 \*\*写法:\*\*以 \#ifdef 加平台标识 开头,以 \#endif 结尾。 平台标识 <table> <thead> <tr> <th>值</th> <th>平台</th> <th>参考文档</th> </tr> </thead> <tbody> <tr> <td>APP-PLUS</td> <td>5+App</td> <td><a href="http://www.html5plus.org/doc/" rel="nofollow">HTML5+ 规范</a></td> </tr> <tr> <td>H5</td> <td>H5</td> <td></td> </tr> <tr> <td>MP-WEIXIN</td> <td>微信小程序</td> <td><a href="https://developers.weixin.qq.com/miniprogram/dev/api/" rel="nofollow">微信小程序</a></td> </tr> <tr> <td>MP-ALIPAY</td> <td>支付宝小程序</td> <td><a href="https://docs.alipay.com/mini/developer/getting-started" rel="nofollow">支付宝小程序</a></td> </tr> <tr> <td>MP-BAIDU</td> <td>百度小程序</td> <td><a href="https://smartprogram.baidu.com/docs/develop/tutorial/codedir/" rel="nofollow">百度小程序</a></td> </tr> <tr> <td>MP-TOUTIAO</td> <td>头条小程序</td> <td><a href="https://developer.toutiao.com/dev/cn/mini-app/develop/framework/basic-reference/introduction" rel="nofollow">头条小程序</a></td> </tr> <tr> <td>MP-QQ</td> <td>QQ小程序</td> <td>(目前仅cli版支持)</td> </tr> <tr> <td>MP</td> <td>微信小程序/支付宝小程序/百度小程序/头条小程序/QQ小程序</td> <td></td> </tr> </tbody> </table> ##### 15.1 组件的条件注释 ##### 代码演示 <!-- #ifdef H5 --> <view> h5页面会显示 </view> <!-- #endif --> <!-- #ifdef MP-WEIXIN --> <view> 微信小程序会显示 </view> <!-- #endif --> <!-- #ifdef APP-PLUS --> <view> app会显示 </view> <!-- #endif --> ##### 15.2 api的条件注释 ##### 代码演示 onLoad () { //#ifdef MP-WEIXIN console.log('微信小程序') //#endif //#ifdef H5 console.log('h5页面') //#endif } ##### 15.3 样式的条件注释 ##### 代码演示 /* #ifdef H5 */ view{ height: 100px; line-height: 100px; background: red; } /* #endif */ /* #ifdef MP-WEIXIN */ view{ height: 100px; line-height: 100px; background: green; } /* #endif */ ## 16. uni-app 中的导航跳转 ## ##### 16.1 利用navigator进行跳转 ##### navigator详细文档:[文档地址][Link 6] 跳转到普通页面 <navigator url="/pages/about/about"> <button type="default">跳转到关于页面</button> </navigator> 跳转到tabbar页面 <navigator url="/pages/message/message" open-type="switchTab"> <button type="default">跳转到message页面</button> </navigator> ##### 16.2 利用编程式导航进行跳转 ##### 导航跳转文档 **利用navigateTo进行导航跳转** 保留当前页面,跳转到应用内的某个页面,使用`uni.navigateBack`可以返回到原页面。 <button type="primary" @click="goAbout">跳转到关于页面</button> 通过navigateTo方法进行跳转到普通页面 goAbout () { uni.navigateTo({ url: '/pages/about/about', }) } **通过switchTab跳转到tabbar页面** 跳转到tabbar页面 <button type="primary" @click="goMessage">跳转到message页面</button> 通过switchTab方法进行跳转 goMessage () { uni.switchTab({ url: '/pages/message/message' }) } **redirectTo进行跳转** 关闭当前页面,跳转到应用内的某个页面。 <!-- template --> <button type="primary" @click="goMessage">跳转到message页面</button> <!-- js --> goMessage () { uni.switchTab({ url: '/pages/message/message' }) } **通过onUnload测试当前组件确实卸载** onUnload () { console.log('组件卸载了') } **注意**:凡是写在当前组件的跳转都无法返回 ##### 16.3 导航跳转传递参数 ##### 在导航进行跳转到下一个页面的同时,可以给下一个页面传递相应的参数,接收参数的页面可以通过onLoad生命周期进行接收 传递参数的页面 goAbout () { uni.navigateTo({ url: '/pages/about/about?id=80', }); } 接收参数的页面 <script> export default { onLoad (options) { console.log(options) } } </script> ## 17. uni-app 中的组件 ## 在`uni-app`中,可以通过创建一个`后缀名为vue`的文件,即创建一个组件成功,其他组件可以将该组件通过`impot的方式导入`,在通过`components进行注册`即可(与vue中 用法一致) ##### 17.1 组件的创建及使用 ##### * 创建login组件,在component中创建login目录,然后新建login.vue文件 <template> <view> 这是一个自定义组件 </view> </template> <script> </script> <style> </style> * 在其他组件中导入该组件并注册 import login from "@/components/test/test.vue" * 注册组件 components: { test} * 使用组件 <test></test> ##### 17.2 组件的生命周期函数 ##### <table> <thead> <tr> <th>beforeCreate</th> <th>在实例初始化之后被调用。<a href="https://cn.vuejs.org/v2/api/#beforeCreate" rel="nofollow">详见</a></th> <th></th> <th></th> </tr> </thead> <tbody> <tr> <td>created</td> <td>在实例创建完成后被立即调用。<a href="https://cn.vuejs.org/v2/api/#created" rel="nofollow">详见</a></td> <td></td> <td></td> </tr> <tr> <td>beforeMount</td> <td>在挂载开始之前被调用。<a href="https://cn.vuejs.org/v2/api/#beforeMount" rel="nofollow">详见</a></td> <td></td> <td></td> </tr> <tr> <td>mounted</td> <td>挂载到实例上去之后调用。<a href="https://cn.vuejs.org/v2/api/#mounted" rel="nofollow">详见</a> 注意:此处并不能确定子组件被全部挂载,如果需要子组件完全挂载之后在执行操作可以使用<code>$nextTick</code><a href="https://cn.vuejs.org/v2/api/#Vue-nextTick" rel="nofollow">Vue官方文档</a></td> <td></td> <td></td> </tr> <tr> <td>beforeUpdate</td> <td>数据更新时调用,发生在虚拟 DOM 打补丁之前。<a href="https://cn.vuejs.org/v2/api/#beforeUpdate" rel="nofollow">详见</a></td> <td>仅H5平台支持</td> <td></td> </tr> <tr> <td>updated</td> <td>由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子。<a href="https://cn.vuejs.org/v2/api/#updated" rel="nofollow">详见</a></td> <td>仅H5平台支持</td> <td></td> </tr> <tr> <td>beforeDestroy</td> <td>实例销毁之前调用。在这一步,实例仍然完全可用。<a href="https://cn.vuejs.org/v2/api/#beforeDestroy" rel="nofollow">详见</a></td> <td></td> <td></td> </tr> <tr> <td>destroyed</td> <td>Vue 实例销毁后调用。调用后,Vue 实例指示的所有东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。<a href="https://cn.vuejs.org/v2/api/#destroyed" rel="nofollow">详见</a></td> <td></td> <td></td> </tr> </tbody> </table> ##### 17.3 组件的通讯 ##### 父组件给子组件传值 通过`props`来接受外界传递到组件内部的值 <template> <view> 这是一个自定义组件 { {msg}} </view> </template> <script> export default { props: ['msg'] } </script> <style> </style> 其他组件在使用login组件的时候传递值 <template> <view> <test :msg="msg"></test> </view> </template> <script> import test from "@/components/test/test.vue" export default { data () { return { msg: 'hello' } }, components: { test} } </script> 子组件给父组件传值 通过`$emit触发事件`进行传递参数 <template> <view> 这是一个自定义组件 { {msg}} <button type="primary" @click="sendMsg">给父组件传值</button> </view> </template> <script> export default { data () { return { status: '打篮球' } }, props: { msg: { type: String, value: '' } }, methods: { sendMsg () { this.$emit('myEvent',this.status) } } } </script> 父组件定义自定义事件并接收参数 <template> <view> <test :msg="msg" @myEvent="getMsg"></test> </view> </template> <script> import test from "@/components/test/test.vue" export default { data () { return { msg: 'hello' } }, methods: { getMsg (res) { console.log(res) } }, components: { test} } </script> 兄弟组件通讯 通过`uni.$emit触发事件`进行传递参数 通过`uni.$on接收事件`进行传递参数 <template> <view> <view>test2 的值---{ {num}}</view> <view><button type="warn" @click="addTest">给test+1</button></view> </view> </template> <script> export default { data() { return { num:1 }; }, created(){ uni.$on('test2',val=>{ this.num += val }) }, methods:{ addTest(){ uni.$emit('test',1) } } } </script> <style> </style> ## 18. uni-ui 的使用 ## [uni-ui文档][uni-ui] 1、点击进入要使用的组件 2、使用HBuilderX导入该组件 3、根据组件提示操作,进行配置(此处以`Grid 宫格`为例) import uniGrid from "@/components/uni-grid/uni-grid.vue" import uniGridItem from "@/components/uni-grid-item/uni-grid-item.vue" 4、注册组件 components: {uniGrid,uniGridItem} 5、使用组件 <uni-grid :column="3"> <uni-grid-item> <text class="text">文本</text> </uni-grid-item> <uni-grid-item> <text class="text">文本</text> </uni-grid-item> <uni-grid-item> <text class="text">文本</text> </uni-grid-item> </uni-grid> ## 最后还是留个官网地址吧,参数众多,官网撑场:[https://uniapp.dcloud.io/][uni-app];奥利个i ## [uni-app]: https://uniapp.dcloud.io/ [Vue.js]: https://vuejs.org/ [Link 1]: https://www.dcloud.io/hbuilderx.html [Link 2]: https://developers.weixin.qq.com/miniprogram/dev/devtools/download.html [Link 3]: https://uniapp.dcloud.io/quickstart [Vue _ _SFC_]: https://vue-loader.vuejs.org/zh/spec.html [uni-app 1]: https://uniapp.dcloud.io/component/README [uni-app 2]: https://uniapp.dcloud.io/api/README [Link 4]: https://uniapp.dcloud.io/collocation/pages?id=globalstyle [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2N3cTUyMW8_size_16_color_FFFFFF_t_70]: /images/20230209/aff407dccc46439e96521f113a311969.png [watermark_type_ZmFuZ3poZW5naGVpdGk_shadow_10_text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2N3cTUyMW8_size_16_color_FFFFFF_t_70 1]: /images/20230209/449bebd322b5428ba59277ae3b29cc82.png [api]: https://uniapp.dcloud.io/api/ui/pulldown [https_uniapp.dcloud.io_api_request_request_id_request]: https://uniapp.dcloud.io/api/request/request?id=request [Link 5]: https://uniapp.dcloud.io/api/storage/storage?id=setstorage [API]: https://uniapp.dcloud.io/api/media/image [Link 6]: https://uniapp.dcloud.io/component/navigator [uni-ui]: https://uniapp.dcloud.io/component/README?id=uniui
相关 Cobra 使用简要(万字带你轻松上手 Cobra 使用) 介绍 欢迎阅读本文,本文将介绍如何使用 Go 语言中的 Cobra 库快速实现一个强大的命令行客户端。命令行客户端在软件开发中扮演着重要的角色,它们提供了一种简单而直接的 朴灿烈づ我的快乐病毒、/ 2024年04月06日 15:21/ 0 赞/ 52 阅读
相关 计算机网络概述(让你轻松了解网络) > 美丽的花虽然会凋谢,可是盛开的时刻值得欣赏。要在美好的时候创造出美好的东西,人生才会充满意义。 文章目录 1.计算机网络在信息时代的作用 2.因特网 待我称王封你为后i/ 2023年07月17日 11:19/ 0 赞/ 22 阅读
相关 让你轻松上手【uni-app】 目标 > uni-app 的基本使用 > 环境搭建 + 页面外观配置 > 组件的使用 > uni-app中样式学习 > 在uni-app中使用字体图标和开 旧城等待,/ 2023年02月27日 12:27/ 0 赞/ 30 阅读
相关 5分钟让你了解UniApp uni-app 是一个使用 Vue.js 开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、H5、以及各种小程序(微信/支付宝/百度/头条/QQ/钉钉 约定不等于承诺〃/ 2023年01月20日 03:00/ 0 赞/ 36 阅读
相关 三分钟让你上手小程序canvas合成海报 一,先准备素材(图片与文字) 根据业务需求准备好素材与需要的文字内容 二,了解微信api 了解微信小程序配合canvas使用的一些api 例如(wx.create 我就是我/ 2022年10月01日 11:44/ 0 赞/ 180 阅读
相关 轻松让你的nginx服务器支持HTTP2协议 文章目录 简介 HTTP1.1和HTTP2 安装最新的nginx 开启HTTP2支持 添加SSL支持 修改加密算法 Diffie 小灰灰/ 2022年09月09日 01:53/ 0 赞/ 192 阅读
相关 linux 工具集,让你轻松运维linux 有一个[linux工具集][linux]的总结,个人觉得很不错,分享下: Linux基础 1. 学会使用命令帮助 2. 文件及目录管理 3. 文本处理 4. ╰半橙微兮°/ 2022年05月24日 05:37/ 0 赞/ 234 阅读
相关 Runtime- 结合Demo, 让你轻松搞定 ![Image 1][] Runtime.jpeg > 关于`Runtime`的学习资料网上有很多了,但是大部分看起来有些晦涩难懂,看过一遍后让人感觉有些走马观花, 还是理 爱被打了一巴掌/ 2022年03月31日 11:22/ 0 赞/ 243 阅读
相关 NLP(十六)轻松上手文本分类 背景介绍 文本分类是NLP中的常见的重要任务之一,它的主要功能就是将输入的文本以及文本的类别训练出一个模型,使之具有一定的泛化能力,能够对新文本进行较好地预测。它的应 偏执的太偏执、/ 2021年11月02日 13:42/ 0 赞/ 365 阅读
还没有评论,来说两句吧...