相关推荐recommended
uniapp详细介绍
作者:mmseoamin日期:2023-11-30

一,什么是uni-app

  1. uni-app是一个使用 Vue.js 开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、Web(响应式)、以及各种小程序(微信/支付宝/百度/头条/飞书/QQ/快手/钉钉/淘宝)、快应用等多个平台
  2. 其实uni-app是微信小程序与vue的结合体,语法基本保持是保持一致,唯一不同的是uni-app中没有div和span标签,如果你已经掌握了vue与微信小程序中的任意一个,恭喜你,你就可以做uni-app开发了

二,开发工具

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

三,新建一个项目

1,新建项目
  1. 点击HbuilderX菜单栏文件>项目>新建
  2. 选择uni-app,填写项目名称,项目创建的目录uniapp详细介绍,在这里插入图片描述,第1张
2,Hbuilde界面

uniapp详细介绍,在这里插入图片描述,第2张

3,文件的介绍uniapp详细介绍,在这里插入图片描述,第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端

    uniapp详细介绍,在这里插入图片描述,第4张

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

      uniapp详细介绍,在这里插入图片描述,第5张

    2. 在Hbuilderx工具中配置微信开发者工具的地址uniapp详细介绍,在这里插入图片描述,第6张

    uniapp详细介绍,在这里插入图片描述,第7张

    1. 配置微信小程序id

      uniapp详细介绍,在这里插入图片描述,第8张

    2. 运行到微信小程序

      uniapp详细介绍,在这里插入图片描述,第9张

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

      uniapp详细介绍,在这里插入图片描述,第10张

    2. 配置模拟器的端口号uniapp详细介绍,List item,第11张

      uniapp详细介绍,在这里插入图片描述,第12张

    夜神模拟器端口号:62001

    海马模拟器端口号:26944

    逍遥模拟器端口号:21503

    MuMu模拟器端口号:7555

    天天模拟器端口号:6555

    1. 运行到模拟器

      uniapp详细介绍,在这里插入图片描述,第13张

    五,uni-app的相关语法

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

    1,文本渲染
    		{{title}}
    		
    		
        export default {
    		data() {
    			const currentDate = this.getDate({
    				format: true
    			})
    			return {
    				title: '明天就要静默了',
    				str: "明天周五放假",
    			}
    		},
    
    2,条件渲染
    		奖励一套房
    		奖励一个媳妇
    		奖励一辆车
    		啥也别想了
    		
    	   export default {
    		 data() {
    			const currentDate = this.getDate({
    				format: true
    			})
    			return {
    				score: 82,
    			}
    		}
    
    3,列表渲染
            //遍历数组
            
    			{{item}}
    		
    		//遍历对象
    		
    			{{value}}
    		
    		//遍历数字
    		
    			{{item}}
    		
    		
    	 export default {
    		data() {
    			const currentDate = this.getDate({
    				format: true
    			})
    			return {
    				obj: {
    					name: "张三",
    					age: 18,
    					job: "teacher"
    				},
    				num: 5,
    				list: ['vue', '小程序', 'uni', 'jquery'],
    	
    			}
    		},
    
    4,数据的双向绑定
    		数据双向绑定
    		
    		
    	 export default {
    		data() {
    			const currentDate = this.getDate({
    				format: true
    			})
    			return {
    				obj: {
    					name: "张三",
    					age: 18,
    					job: "teacher"
    				},
    				num: 5,
    			}
    		},
    
    5,属性绑定
    		
    		
    	
    	export default {
    		data() {
    			const currentDate = this.getDate({
    				format: true
    			})
    			return {
    				obj: {
    					name: "张三",
    					age: 18,
    					job: "teacher"
    				},
    				title: 'Hello',
    				num: 5,
    				title: '明天就要静默了',
    				str: "明天周五放假",
    				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?之后的那一块
          
          
          • 在跳转后的页面接收参数
            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
            

            uniapp详细介绍,在这里插入图片描述,第14张

            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