首页IT科技uniapp总结(uniapp详细介绍)

uniapp总结(uniapp详细介绍)

时间2025-08-04 21:07:09分类IT科技浏览4264
导读:一,什么是uni-app uni-app是一个使用 Vue.js 开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、Web(响应式)、以及各种小程序(微信/支付宝/百度/头条/飞书/QQ/快手/钉钉/淘宝)、快应用等多个平台...

一              ,什么是uni-app

uni-app是一个使用 Vue.js 开发所有前端应用的框架                    ,开发者编写一套代码       ,可发布到iOS              、Android                    、Web(响应式)       、以及各种小程序(微信/支付宝/百度/头条/飞书/QQ/快手/钉钉/淘宝)              、快应用等多个平台

其实uni-app是微信小程序与vue的结合体              ,语法基本保持是保持一致                    ,唯一不同的是uni-app中没有div和span标签       ,如果你已经掌握了vue与微信小程序中的任意一个       ,恭喜你                    ,你就可以做uni-app开发了

二             ,开发工具

Hbuilderx 微信开发者工具 安卓模拟器(雷电       ,mumu)

三                     ,新建一个项目

1             ,新建项目 点击HbuilderX菜单栏文件>项目>新建 选择uni-app,填写项目名称,项目创建的目录 2                     ,Hbuilde界面

3                    ,文件的介绍

4,文件目录 pages.json :文件用来对 uni-app 进行全局配置              ,决定页面文件的路径                    、窗口样式       、原生的导航栏       、底部的原生tabbar 等 manifest.json :文件是应用的配置文件                    ,用于指定应用的名称                    、图标             、权限等              。 App.vue:是我们的跟组件       ,所有页面都是在App.vue下进行切换的              ,是页面入口文件                    ,可以调用应用的生命周期函数                    。 main.js:是我们的项目入口文件       ,主要作用是初始化vue实例并使用需要的插件       。 uni.scss:文件的用途是为了方便整体控制应用的风格              。比如按钮颜色       、边框风格       ,uni.scss文件里预置了一批scss变量预置                    。 unpackage:就是打包目录                    ,在这里有各个平台的打包文件 pages:所有的页面存放目录 static:静态资源目录             ,例如图片等 components:组件存放目录

四       ,运行项目

1                     ,H5端

2             ,小程序端 打开开发工具的服务端口

在Hbuilderx工具中配置微信开发者工具的地址

配置微信小程序id

运行到微信小程序

3,模拟器端(mumu) 首先要打开我们的模拟器                     ,保证他处于开启状态

配置模拟器的端口号

夜神模拟器端口号:62001

海马模拟器端口号:26944

逍遥模拟器端口号:21503

MuMu模拟器端口号:7555

天天模拟器端口号:6555

运行到模拟器

五                    ,uni-app的相关语法

其实uni-app是微信小程序与vue的结合体,语法基本保持是保持一致              ,唯一不同的是uni-app中没有div和span标签                    ,如果你已经掌握了vue与微信小程序中的任意一个       ,恭喜你              ,你就可以做uni-app开发了

1                    ,文本渲染 <view class="">{{title}}</view> <view class="" v-text="title"></view> <view class="" v-html="str"></view> export default { data() { const currentDate = this.getDate({ format: true }) return { title: 明天就要静默了, str: "<strong>明天周五放假</strong>", } }, 2       ,条件渲染 <view class="" v-if="score>=90">奖励一套房</view> <view class="" v-else-if="score>=90">奖励一个媳妇</view> <view class="" v-else-if="score>=80">奖励一辆车</view> <view class="" v-else>啥也别想了</view> export default { data() { const currentDate = this.getDate({ format: true }) return { score: 82, } } 3       ,列表渲染 //遍历数组 <view class="" v-for="(item,index) in list" :key="index"> {{item}} </view> //遍历对象 <view v-for="(value,key) in obj" v-bind:key="key"> {{value}} </view> //遍历数字 <view v-for="item in 5" :key="item"> {{item}} </view> export default { data() { const currentDate = this.getDate({ format: true }) return { obj: { name: "张三", age: 18, job: "teacher" }, num: 5, list: [vue, 小程序, uni, jquery], } }, 4                    ,数据的双向绑定 <view class="title">数据双向绑定</view> <button @click="num++">{{num}}</button> <input type="text" v-model="num" class="ipt"> export default { data() { const currentDate = this.getDate({ format: true }) return { obj: { name: "张三", age: 18, job: "teacher" }, num: 5, } }, 5             ,属性绑定 <button type="primary" v-bind:disabled="flag" @click="flag=!flag">按钮</button> <button type="warn" v-bind:disabled="!flag" @click="flag=!flag">按钮</button> export default { data() { const currentDate = this.getDate({ format: true }) return { obj: { name: "张三", age: 18, job: "teacher" }, title: Hello, num: 5, title: 明天就要静默了, str: "<strong>明天周五放假</strong>", score: 82, flag: true, list: [vue, 小程序, uni, jquery], date: currentDate, time: 12:01 } },

六       ,uni-app的生命周期

1                     ,vue生命周期 beforeCreate:创建前             ,没有this created:创建后;此时已经有了this,我们可以做的是发起ajax请求,监听事件                     ,设置定时器 beforeMounte:挂在前                    ,此时只有虚拟dom mounted:挂载后;此时我们可以操作dom beforeUpdate:更新前 updated:更新后 beforeDestroy:销毁前;可以做的是移除监听事件,移除定时器 2              ,小程序生命周期 onLoad:加载类似于vue中的created生命周期 onShow:页面显示时执行 onReady:准备 onHide:后台运行时执行 onUnload:卸载

七                    ,路由

1       ,导航路由:navigator

opentype打开类型:

navigate跳转

redirect重定向(当前页面不留历史记录)

navigateBack返回

relauch 重启

switchTab 跳转底部栏 2              ,路由传参 路由参数是在拼接在url?之后的那一块 <navigator url="pages/index/index?name=mumu&age=18"></navigator> 在跳转后的页面接收参数 onLoad(option){ console.log(options) //{name:mumu,age:18} } 3                    ,路由常用api //跳转 uni.navigateTo({url}) //重定向 uni.redirectTo({url}) //返回 uni.navigateBack() //切换底部栏 uni.switchTab() //重启 uni.reLaunch()

八       ,条件编译

1       ,什么是条件编译?

不同的平台展示不同特性与功能

条件编译是用特殊的注释作为标记                    ,在编译时根据这些特殊的注释             ,将注释里面的代码编译到不同平台       。 2       ,语法

APP —— App端

H5 —— 网页

MP —— 小程序

MP-WEIXIN —— 微信小程序 //#ifdef 平台专有 //#endif 3                     ,css条件编译 /* #ifdef APP */ .active{color:red} /* #endif */ 4             ,js条件编译 // #ifdef APP-PLUS uni.showModal({ title:"你好App用户" }) // #endif 5,条件编译 pages.json “style             ”:{ "h5":{ "titleNView":{ "titleText":"我是H5" } }, "app-plus": { "titleNView":false //隐藏导航栏 } } // #ifdef MP-WEIXIN || APP { "path":"pages/condition/we", "style":{ "navigationBarTitleText": "小程序专有页面" } }, // #endif

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
gettype方法(利用gravatar()函数获取Typecho程序主题中作者头像) 大型开源数据库(名家访谈 开源数据库 Affinity 介绍和 Affinity 研发团队深度采访)