uniapp学习(二)
easycom自动导入自定义组件
目录下 components / MyItem /MyItem.vue
<template>
<view>
<view class="item">
(。・∀・)ノ゙嗨
</view>
</view>
</template>
<style lang="scss">
.item{
width: 200rpx;
height:200rpx;
background-color: orange;
}
</style>
使用
<template>
<view>
<MyItem></MyItem>
<!-- 其他东西 -->
</view>
</template>
props父向子组件传值
父传子
<!-- 组件 Components/MyItem.vue-->
<view class="pubTitle">
<view class="big">
{{title}}
</view>
<view class="small">
{{subtitle}}
</view>
<view class="line">
</view>
</view>
</template>
<script>
export default {
props:["title","subtitle"],
data() {
return {
};
}
}
</script>
<style lang="scss">
.pubTitle{
padding: 60rpx 30rpx;
text-align: center;
.big{
font-size: 50rpx;
font-weight: 600;
color: #333;
}
.small{
font-size: 28rpx;
color: #888;
}
.line{
display: inline-block;
width: 80rpx;
height: 8rpx;
background-color: #1AA034;
border-radius: 10rpx;
}
}
</style>
使用组件方
<MyItem title="首页" subtitle="index Page"></MyItem>
<!-- 驼峰写法也好使 -->
<My-item title="首页" subtitle="index Page"></My-item>
绑定动态值及数据类型默认值
动态传值的使用组件方
<template>
<view>
<MyItem :title="text" :subtitle="subtitle"></MyItem>
</view>
</template>
<script>
export default {
data(){
return{
text:"(。・∀・)ノ゙嗨",
subtitle:"┗|`O′|┛ 嗷~~"
};
}
}
</script>
数据默认值的组件方
<template>
<view class="pubTitle">
<view class="time">
{{time}}
</view>
<view class="big">
{{title}}
</view>
<view class="small">
{{subtitle}}
</view>
<view class="list">
{{list}}
</view>
<view class="obj">
{{obj}}
</view>
<view class="line">
</view>
</view>
</template>
<script>
export default {
// props:["title","subtitle"],
props:{
title:{
type: String,
default:"默认标题"
},
subtitle:{
type: String,
default:"默认副标题"
},
// 父组件传值时。除string都要v-bind
time:{
type: Number,
default:Date.now()
},
// 数组和对象都得 default() return
list:{
type:Array,
default(){
return [1,2,3]
}
},
obj:{
type:Object,
default(){
return {
a:1,
b:2
}
}
}
},
data() {
return {
};
}
}
</script>
emit子向父组件传值
子组件
<template>
<view>
<view class="" >
<input type="text" placeholder="请输入"
@input="inputsomeThing"
>
</view>
</view>
</template>
<script>
export default {
methods:{
inputsomeThing(e){
// this.$emit(事件名,值)
// 只传单值
// this.$emit("myenv", {
// e.detail.value,
// )
// 传对象(多值)
this.$emit("myenv", {
value:e.detail.value,
time:Date.now()
})
}
}
}
</script>
父组件
<template>
<view class="box">
<myEvent @myenv="myenv"></myEvent>
</view>
</template>
<script>
export default {
data(){
return{
};
},
methods:{
myenv(e){
console.log(e)
}
}
}
</script>
native 修饰符与父子间通信传值
父组件
<template>
<view class="box">
<myEvent
@myenv="myenv"
@click.native="onCLick"
></myEvent>
<!--
就是你写 @click,它会以为我们自定义了个事件
所以后面加个native,说明这是原生的,不是在父子组件通信的
-->
<button @click="turnON">开启</button>
<!-- 核心还是通过props传数据给子组件,只是结合了使用修饰符让原生事件在子组件标签上生效而已-->
<!-- 数据向下走,方法向上走 -->
<mypop :state="state"
@fade="fade"
></mypop>
</view>
</template>
<!-- <box-icon name='home-alt-2' flip='horizontal' color='#a09898' ></box-icon> -->
<script>
export default {
data(){
return{
state:false
};
},
methods:{
myenv(e){
console.log(e)
},
onCLick(){
console.log("(。・∀・)ノ゙嗨")
},
turnON(){
this.state = true
},
fade(e){
this.state = e
}
}
}
</script>
子组件 myEvent
<template>
<view>
<view class="" >
<input type="text" placeholder="请输入"
@input="inputsomeThing"
>
</view>
</view>
</template>
<script>
export default {
data() {
return {
};
},
methods:{
// e.detail.value
inputsomeThing(e){
// 事件名,使用时前面加on
// 只传单值
// this.$emit("myenv", {
// e.detail.value,
// )
// 传多值
this.$emit("myenv", {
value:e.detail.value,
time:Date.now()
})
}
}
}
</script>
子组件 mypop
<template>
<view>
<view class="pop"
:style="{display: state? 'block':'none'}"
>
</view>
<button size="mini" @click="fade">关闭</button>
<view class="">
(。・∀・)ノ゙嗨
</view>
</view>
</template>
<script>
export default {
name:"mypop",
props:{
state:{
type:Boolean,
default:false
}
},
data() {
return {
};
},
methods:{
fade(){
this.$emit("fade",false)
}
}
}
</script>
<style lang="scss">
.pop{
height: 300rpx;
width: 300rpx;
background-color: cornflowerblue;
}
</style>
sync修饰符以及update的实现原理
两种方法对比
不使用sync
父组件
<template>
<view class="box">
<button @click="turnON">开启</button>
<mypop :state="mystate"
@update:state = "aaa"
></mypop>
</view>
</template>
<script>
export default {
data(){
return{
mystate:false
};
},
methods:{
turnON(){
this.mystate = true
},
aaa(e){
this.mystate = e
}
}
}
</script>
子组件
<template>
<view>
<view class="pop"
:style="{display: state? 'block':'none'}"
>
</view>
<button size="mini" @click="fade">关闭</button>
<view class="">
(。・∀・)ノ゙嗨
</view>
</view>
</template>
<script>
export default {
name:"mypop",
props:{
state:{
type:Boolean,
default:false
}
},
data() {
return {
};
},
methods:{
fade(){
this.$emit("update:state",false)
}
}
}
</script>
<style lang="scss">
.pop{
height: 300rpx;
width: 300rpx;
background-color: cornflowerblue;
}
</style>
使用sync
父组件
<template>
<view class="box">
<button @click="turnON">开启</button>
<!-- 使用.sync可以修改父子局传来的值但无法触发自定义事件 -->
<!-- 如果选的时vue3的话,父组件需要写成“v-model:state” -->
<mypop :state.sync="mystate" ></mypop>
</view>
</template>
<!-- <box-icon name='home-alt-2' flip='horizontal' color='#a09898' ></box-icon> -->
<script>
export default {
data(){
return{
mystate:false
};
},
methods:{
turnON(){
this.mystate = true
}
}
}
</script>
子组件
<template>
<view>
<view class="pop"
:style="{display: state? 'block':'none'}"
>
</view>
<button size="mini" @click="fade">关闭</button>
<view class="">
(。・∀・)ノ゙嗨
</view>
</view>
</template>
<script>
export default {
name:"mypop",
props:{
state:{
type:Boolean,
default:false
}
},
data() {
return {
};
},
methods:{
fade(){
this.$emit("update:state",false)
}
}
}
</script>
<style lang="scss">
.pop{
height: 300rpx;
width: 300rpx;
background-color: cornflowerblue;
}
</style>
vue中的生命周期和小程序周期的对比
VUE的生命周期 https://www.jianshu.com/p/4f8daeafe58f

普通vue页面
<template>
<view class="box">
</view>
</template>
<script>
export default {
data(){
return{
};
},
methods:{
interval(){
console.log("自定义函数")
}
},
created(){
this.interval()
//网络请求
console.log("这是 index created")
},
mounted(){
//数据渲染
console.log("index mounted")
}
}
</script>
APP.vue页面
也可以使用 mounted ,created 都会自动转化。但既然它本身使用了onLaunch这些东西,就用就行,不用往上添加了。
<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>
uniapp学习(二)的更多相关文章
- uni-app学习(二)
1. uni-app学习(二) 1.1. 好用css记录 一定透明度的背景色background: rgba(255,255,255,.6); 1.2. 好用的代码段 store(用户登录) expo ...
- uni-app学习(五)好用的插件3
1. uni-app学习(五)好用的插件3 1.1. 分享推广页面 分享推广页面,分享第三方.保存二维码.复制推广地址 模板地址 示例 这个用到的几率还是蛮大的,可以直接拿来修改下用 1.2. 教育A ...
- emberjs学习二(ember-data和localstorage_adapter)
emberjs学习二(ember-data和localstorage_adapter) 准备工作 首先我们加入ember-data和ember-localstorage-adapter两个依赖项,使用 ...
- ReactJS入门学习二
ReactJS入门学习二 阅读目录 React的背景和基本原理 理解React.render() 什么是JSX? 为什么要使用JSX? JSX的语法 如何在JSX中如何使用事件 如何在JSX中如何使用 ...
- TweenMax动画库学习(二)
目录 TweenMax动画库学习(一) TweenMax动画库学习(二) TweenMax动画库学习(三) Tw ...
- Hbase深入学习(二) 安装hbase
Hbase深入学习(二) 安装hbase This guidedescribes setup of a standalone hbase instance that uses the local fi ...
- Struts2框架学习(二) Action
Struts2框架学习(二) Action Struts2框架中的Action类是一个单独的javabean对象.不像Struts1中还要去继承HttpServlet,耦合度减小了. 1,流程 拦截器 ...
- Python学习二:词典基础详解
作者:NiceCui 本文谢绝转载,如需转载需征得作者本人同意,谢谢. 本文链接:http://www.cnblogs.com/NiceCui/p/7862377.html 邮箱:moyi@moyib ...
- Quartz学习--二 Hello Quartz! 和源码分析
Quartz学习--二 Hello Quartz! 和源码分析 三. Hello Quartz! 我会跟着 第一章 6.2 的图来 进行同步代码编写 简单入门示例: 创建一个新的java普通工程 ...
- SpringCloud学习(二):微服务入门实战项目搭建
一.开始使用Spring Cloud实战微服务 1.SpringCloud是什么? 云计算的解决方案?不是 SpringCloud是一个在SpringBoot的基础上构建的一个快速构建分布式系统的工具 ...
随机推荐
- Java 生成海报
最近项目有个功能是生成海报 一个背景图片,一个二维码图片 将两个图片合并成一个图片. 写了一个工具类,需要的朋友自取. 1 @Component 2 public class PictureUtil ...
- 一文吃透Elasticsearch
本文已经收录到Github仓库,该仓库包含计算机基础.Java基础.多线程.JVM.数据库.Redis.Spring.Mybatis.SpringMVC.SpringBoot.分布式.微服务.设计模式 ...
- 一款能“干掉” ChatGPT 的应用「GitHub 热点速览」
据说有了它,ChatGPT 就可以靠边站了.因为 Auto-GPT 能更加主动地完成你给他的指定任务,不用做更多的人为干涉,它的推理能力比 ChatGPT 更强,有人用它解放双手做了个 React 网 ...
- Go语言入门实战: 猜谜游戏+在线词典
包含基础语法和入门Go语言的3个案例 速览基础语法 对于耳熟能详的顺序结构.分支结构(if else-if else.switch).循环结构(for)不作赘述. 数组: 长度固定的元素序列 pack ...
- 关于 OAuth 你又了解哪些?
作者罗锦华,API7.ai 技术专家/技术工程师,开源项目 pgcat,lua-resty-ffi,lua-resty-inspect 的作者. OAuth 的背景 OAuth,O 是 Open,Au ...
- API 网关日志的价值,你了解多少?
本文介绍了 API 网关日志的价值,并以知名网关 Apache APISIX 为例,展示如何集成 API 网关日志. 作者钱勇,API7.ai 技术工程师,Apache APISIX Committe ...
- RTSP Server(LIVE555)源码分析(五)-PLAY信令
主要分析RTSPServer::RTSPClientSession针对客户端PLAY事件处理 一. PLAY信令,handleCmd_withinSession源码解析 1)步骤1.03,当RTSP客 ...
- 2022-06-10:薯队长从北向南穿过一片红薯地(南北长M,东西宽N),红薯地被划分为1x1的方格, 他可以从北边的任何一个格子出发,到达南边的任何一个格子, 但每一步只能走到东南、正南、西南方向的
2022-06-10:薯队长从北向南穿过一片红薯地(南北长M,东西宽N),红薯地被划分为1x1的方格, 他可以从北边的任何一个格子出发,到达南边的任何一个格子, 但每一步只能走到东南.正南.西南方向的 ...
- Grafana系列-统一展示-8-ElasticSearch日志快速搜索仪表板
系列文章 Grafana 系列文章 概述 我们是基于这篇文章: Grafana 系列文章(十二):如何使用 Loki 创建一个用于搜索日志的 Grafana 仪表板, 创建一个类似的, 但是基于 El ...
- 2015年蓝桥杯C/C++大学B组省赛真题(加法变乘法)
题目描述: 我们都知道:1+2+3+ ... + 49 = 1225 现在要求你把其中两个不相邻的加号变成乘号,使得结果为2015 比如: 1+2+3+...+10*11+12+...+27*28+2 ...