IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> uni-app开发和常规Vue开发 -> 正文阅读

[JavaScript知识库]uni-app开发和常规Vue开发

uni-app开发和常规Vue开发

个人博客:uni-app开发和常规Vue开发

uni-app 是一个使用 Vue.js 开发所有前端应用的框架,开发一次,可以发行为App、小程序、网站,

常规Web开发只能发行为网站。

标签

  • Vue中的div标签对应于uni-app是view

  • Vue中的span标签对应于uni-app中是text

生命周期

uni-app中有三种类型的生命周期,应用生命周期、页面生命周期、组件生命周期

应用生命周期

应用生命周期只在App.vue中有效

uni-app支持以下生命周期函数(部分)

函数名说明
onLaunchuni-app初始化完成时触发(全局只触发一次)
onShowuni-app启动时,或从后台进入前台时显示
onHideuni-app从前台进入后台
onErroruni-app报错时触发

app.vue

<script>
	export default {
		onLaunch: function() {
			console.log('App Launch')
		},
		onShow: function() {
			console.log('App Show')
		},
		onHide: function() {
			console.log('App Hide')
		}
	}
</script>

<style>
	/*每个页面公共css */
</style>

页面生命周期

页面生命周期

组件生命周期

Vue组件生命周期

uni-app 组件支持的生命周期,与vue标准组件的生命周期相同

image-20220224165359762

路由

uni-app

uni-app页面路由为框架统一管理,开发者需要在pages.json里配置每个路由页面的路径及页面样式。

新建页面时,会在pages.json中自动生成路由

pages.json

"pages": [ //pages数组中第一项表示应用启动页,参考:https://uniapp.dcloud.io/collocation/pages
		{
			"path": "pages/index/index",
			"style": {
				"navigationBarTitleText": "uni-app"
			}
		}
        ,{
            "path" : "pages/login/login",
            "style" :                                                                                    
            {
                "navigationBarTitleText": "",
                "enablePullDownRefresh": false
            }
            
        }
    ]

uni-app 有两种页面路由跳转方式:使用navigator组件跳转、调用API跳转。

  • 使用navigator组件跳转

    <navigator url="/" class="link">首页</navigator>
    
  • 调用API跳转

    uni.navigateTo({
    	url: '/pages/login/login'
    })
    

pages \ index.vue

<template>
	<view class="index">
		<text class="text">首页</text> 
		<button class="btn" @click="login">登录</button>
	</view>
</template>

<script>
	export default {
		methods: {
			login() {
				uni.navigateTo({
					url: '/pages/login/login'
				})
			}
		}
	}
</script>

<style lang="less" scoped>
	.index {
		text-align: center;
		
		.btn {
			width: 100px;
			height: 50px;
		}
	}
	
</style>

pages \ login \ login.vue

<template>
	<view class="login">
		login
		<navigator url="/" class="link">首页</navigator>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				
			}
		},
		methods: {
			
		}
	}
</script>

<style>
	.login {
		text-align: center;
	}
	.link {
		color: blue;
	}
</style>

uniapp

插一嘴:HBuilderX感觉挺人性化的,缺少的插件保存时会自动帮你安装

image-20220224161236235

Vue路由

Vue路由

相对uni-app的路由设置来说,Vue的路由配置稍稍麻烦一点,先安装vue-router,再建router文件夹,设置路由规则,并导出路由给Vue使用。详情点击上面的链接

Vue3相对于Vue2,也有所变化:Vue3路由

路由守卫

通过安装uni-simple-router插件,实现路由守卫功能

安装npm install uni-simple-router

文档uni-simple-router

使用:快速上手

页面之间传值

通过查询参数

首页

<template>
	<view class="index">
		首页
		<navigator :url="'/pages/login/login?msg='+msg" class="login">登录</navigator>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				msg: 'Hello, login Pages'
			}
		}
	}
</script>

<style lang="less" scoped>
	.index {
		width: 500px;
		text-align: center;
		margin: 20px auto;
	}
	.login {
		color: blue;
	}
</style>

登录页

<template>
	<view class="login">
		<h2>登录</h2>
		首页发送的信息: {{msg}}
	</view>
</template>

<script>
	export default {
		data() {
			return {
				msg: ''
			}
		},
		methods: {
			
		},
		onLoad(options) {		// 其参数为上个页面传递的数据,参数类型为 Object(用于页面传参)
			this.msg = options.msg
		}
	}
</script>

<style scoped>
	.login {
		text-align: center;
		width: 300px;
		margin: 20px auto;
	}
</style>

image-20220225104643142

以下部分,uni-app和常规Vue开发一样,属于是复习内容

父子组件传值

和Vue一样,顺便复习一下

Vue组件间的数据共享

父传子(props)

子组件

<template>
	<view class="son">
		子组件: 父组件发送的信息:{{msg}}
	</view>
</template>

<script>
	export default {
		name:"Son",
		props: {
			msg: {
				type: String,
				default: ''
			}
		}
	}
</script>

<style scoped>
	.son {
		width: 300px;
		height: 150px;
		line-height: 150px;
		background-color: pink;
		margin: 20px auto;
	}
</style>

父组件

<template>
	<view class="index">
		<text class="text">父组件: {{msg}}</text> 
		<Son :msg="msg"></Son>
	</view>
</template>

<script>
	import Son from '../../components/Son.vue'
	export default {
		components: {
			Son
		},
		data() {
			return {
				msg: 'Hello, Son'
			}
		}
	}
</script>

<style lang="less" scoped>
	.index {
		width: 500px;
		height: 250px;
		text-align: center;
		background-color: skyblue;
		margin: 0 auto;
	}
	
</style>

image-20220224181528797

子传父(emit)

子组件

<template>
	<view class="son">
		子组件: {{msg}}
		<button @click="sendMsg">发送信息给父组件</button>
	</view>
</template>

<script>
	export default {
		name:"Son",
		data() {
			return {
				msg: 'Hello Father'
			}
		},
		methods: {
			sendMsg() {
				this.$emit('getMsg', this.msg)
			}
		}
	}
</script>

<style scoped>
	.son {
		width: 300px;
		height: 150px;
		line-height: 150px;
		background-color: pink;
		margin: 20px auto;
	}
</style>

父组件

<template>
	<view class="index">
		<text class="text">父组件: 子组件发送的信息: {{msg}}</text> 
		<Son @getMsg="getMsg"></Son>
	</view>
</template>

<script>
	import Son from '../../components/Son.vue'
	export default {
		components: {
			Son
		},
		data() {
			return {
				msg: ''
			}
		},
		methods: {
			getMsg(msg) {
				this.msg = msg
			}
		}
	}
</script>

<style lang="less" scoped>
	.index {
		width: 500px;
		height: 250px;
		text-align: center;
		background-color: skyblue;
		margin: 0 auto;
	}
	
</style>

uniapp

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-02-26 11:22:00  更:2022-02-26 11:25:25 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 1:46:02-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码