组件其他-组件间父子通信-ref属性-动态组件-插槽-计算属性-监听属性-node环境搭建
目录
组件其他-组件间父子通信-ref属性-动态组件-插槽-计算属性-监听属性-node环境搭建
今日概要
-
1 组件其他
-
2 组件间通信
- 2.1 组件间通信之子传父
- 2.2 组件间通信之父传子
-
3 ref属性
-
4 动态组件
- 4.0 不使用动态组件
- 4.1 动态组件component标签
- 4.2 keep-alive保持组件不销毁
-
5 插槽
- 5.1 匿名插槽
- 5.2 具名插槽
-
6 计算属性
- 6.0 计算属性基本使用
- 6.1 通过计算属性重写过滤案例
-
7 监听属性
-
8 node环境搭建
今日内容详细
1 组件其他
# 根组件 和 组件 一些问题
-new Vue---> 管理div---> 根组件
-自己再定义的全局 局部 是组件
-组件有自己的html css js ---> 数据 事件...
-在组件中 this指代当前组件
-父子组件的data是无法共享的
-data是一个函数 需要有返回值(return)
1.0 组件回顾
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="js/vue.js"></script>
</head>
<body>
<div class="app">
<p>名字:{{name}}</p>
<p>年龄:{{age}}</p>
<hr>
<child></child>
</div>
</body>
<script>
var child = {
template:`
<div>
<button>后退</button>
首页--->{{name}}
<button>前进</button>
</div>
`,
data (){
return{
name: '郑鹏飞'
}
}
}
var vm = new Vue({
el: '.app',
data: {
age: 19
},
methods: {
},
components: {
child
}
})
</script>
</html>
2 组件间通信
2.1 组件间通信之子传父
# 组件间数据不共享---> 需要进行数据传递
# 父传子:使用自定义属性方式
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="js/vue.js"></script>
</head>
<body>
<div class="app">
<p>子组件传递过来的数据: {{mytext}}</p>
<hr>
<child @myevent="handleEvent"></child>
</div>
</body>
<script>
var child = {
template:`
<div>
<input type="text" v-model="mytext">
<button @click="handleSend">点我传递</button>
</div>
`,
data (){
return{
mytext:''
}
},
methods: {
handleSend(){
// 子组件中,触发自定义事件的执行,会执行父组件自定义事件绑定的函数,有几个参数,就传几个参数
this.$emit('myevent',this.mytext)
}
}
}
var vm = new Vue({
el: '.app',
data: {
mytext:''
},
methods: {
handleEvent(mytext){
this.mytext = mytext
}
},
components: {
child
}
})
</script>
</html>
2.2 组件间通信之父传子
# 组件间数据不共享---> 需要进行数据传递
# 父传子:使用自定义属性方式
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
<h1>父子通信之父传子 通过自定义属性--->不能用驼峰 不要跟子组件中变量冲突</h1>
<h2>字符串的age--->age="age"</h2>
<child :age="age"></child>
</div>
</body>
<script>
// 父中有age 子child只有name 没有age 现在把父中的age传到child中 显示
var child = {
template:` <div>
<button>后退</button>
首页--->名字:{{ myname }}--->年龄:{{ age }}
<button>前进</button>
</div>`,
data(){
return{
myname: '郑鹏飞'
}
},
props:{age:Number}
}
var vm = new Vue({
el: '.app',
data: {
age: '19'
},
components: {
child
}
})
</script>
</html>
// props:{age:Number}必须有这个,如果传过来的类型不是这个,页面显示,但是后台报错
3 ref属性
# 自定义属性和自定义事件 可以实现父子传值
# ref属性 可以更方便的实现父子通信
# ref属性放在普通标签上 <input type="text" ref="myinput">
-通过this.$refs.myinput 拿到的是原生dom对象 通过原生dom修改标签
# ref属性放在组件上 <child ref="mychild"></child>
-通过this.$refs.mychild 拿到的是组件对象 既然拿到了组件对象 组件对象中的变量 方法 都能通过直接点.的方式调用
-因此不需要关注是子传父 还是父传子 直接通过组件对象 使用即可
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
<button @click="handleClick">点我</button>---> {{age}}
<br>
<input type="text" ref="myinput">
<div ref="mydiv">我是div</div>
<br>
<child ref="mychild"></child>
</div>
</body>
<script>
// 父中有age,子child 只有name,没有age,现在把父中的age传到child中,显示
var child = {
template: `
<div>
<h1>名字:{{ name }}--->年龄:{{ age }}</h1>
<button @click="handleClick">点我弹出名字</button>
</div>`,
data() {
return {
name: 'lqz',
age: 19
}
},
methods: {
handleClick(){
alert(this.name)
}
}
}
var vm = new Vue({
el: '.app',
data: {
age: 999
},
methods: {
handleClick() {
// 1 ref 属性放在普通标签上,拿到标签的dom对象
// 通过this.$refs可以拿到所有标签上写了ref属性的 标签 ,对象类型 key值是ref对应的value值, value值是原生dom对象
// console.log(this.$refs)
// this.$refs.myinput.value = 'lqz is handsome'
// 重点:以后就不需要关注是子传父还是父传子了,直接通过对象取值赋值即可,而且可以主动调用子组件中的函数
this.$refs.mychild.handleClick()
}
},
components: {
child
}
})
</script>
</html>
4 动态组件
4.0 不使用动态组件
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
<button @click="handleClick('home')">首页</button>|
<button @click="handleClick('order')">订单</button>|
<button @click="handleClick('goods')">商品</button>|
<home v-if="chooseType=='home'"></home>
<order v-else-if="chooseType=='order'"></order>
<goods v-else></goods>
</div>
</body>
<script>
var home = {
template: `
<div>
<h1>home页面</h1>
</div>`,
}
var order = {
template: `
<div>
<h1>order页面</h1>
</div>`,
}
var goods = {
template: `
<div>
<h1>商品页面</h1>
</div>`,
}
var vm = new Vue({
el: '.app',
data: {
chooseType: 'home'
},
methods: {
handleClick(type){
this.chooseType = type
}
},
components: {
home,
order,
goods
}
})
</script>
</html>
4.1 动态组件component标签
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
<button @click="handleClick('home')">首页</button>|
<button @click="handleClick('order')">订单</button>|
<button @click="handleClick('goods')">商品</button>|
<component :is="who"></component>
</div>
</body>
<script>
var home = {
template: `
<div>
<h1>home页面</h1>
</div>`,
}
var order = {
template: `
<div>
<h1>order页面</h1>
</div>`,
}
var goods = {
template: `
<div>
<h1>商品页面</h1>
</div>`,
}
var vm = new Vue({
el: '.app',
data: {
who: 'home'
},
methods: {
handleClick(type){
this.who = type
}
},
components: {
home,
order,
goods
}
})
</script>
</html>
4.2 keep-alive保持组件不销毁
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
<span @click="handleClick('home')">首页</span>| <span @click="handleClick('order')">订单</span> | <span
@click="handleClick('goods')">商品</span>
<keep-alive>
<component :is="who"></component>
</keep-alive>
</div>
</body>
<script>
var home = {
template: `
<div>
<h1>home页面</h1>
</div>`,
}
var order = {
template: `
<div>
<h1>order页面</h1>
</div>`,
}
var goods = {
template: `
<div>
<h1>商品页面</h1>
<input type="text" > <buttont>搜索</buttont>
</div>`,
}
var vm = new Vue({
el: '.app',
data: {
who: 'home'
},
methods: {
handleClick(type) {
this.who = type
}
},
components: {
home,
order, goods
}
})
</script>
</html>
5 插槽
# 一般情况下 编写玩1个组件之后 组件的内容都是写死的 需要加数据 只能去组件中修改 扩展性很差
# 然后就出现了插槽这个概念 只需要在组件中添加<slot></slot> 就可以在body的组件标签中添加内容
6.1 匿名插槽
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
<hr>
<home>
<div>
<img src="sister.jpg" alt="">
</div>
</home>
<hr>
</div>
</body>
<script>
var home = {
template:`<div>
<h1>home页面</h1>
<slot></slot>
<h1>结束了</h1>
<slot></slot>
<slot></slot>
</div>`
}
var vm = new Vue({
el: '.app',
data: {},
components: {
home
}
})
</script>
</html>
// 在body的div中写,会插在<slot></slot>中
5.2 具名插槽
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
</body><!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
<hr>
<home>
<div slot="a">
我是a的div
<img src="sister.jpg" alt="">
</div>
<div slot="b">我是b的div</div>
</home>
<hr>
</div>
</body>
<script>
var home = {
template:`<div>
<h1>home页面</h1>
<slot name="a"></slot>
<h1>结束了</h1>
<slot name="b"></slot>
<slot name="a"></slot>
</div>`
}
var vm = new Vue({
el: '.app',
data: {},
components: {
home
}
})
</script>
</html>
</html>
6 计算属性
# 计算属性只有使用的变量发生变化时 才重新运算
# 计算属性就像python中的property 可以把方法/函数伪装成属性
6.0 计算属性基本使用
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
<!-- 第一种 模板语法 点的方法-->
<!-- <h1>input输入单词 首字母转成大写展示</h1>-->
<!-- <input type="text" v-model="mytext">-–>{{mytext.slice(0,1).toUpperCase() + mytext.slice(1)}}-->
<!-- 第二种 函数方法-->
<!-- <input type="text" v-model="mytext">-–> {{getUpper()}}-->
<!-- 第三种 计算属性-->
<input type="text" v-model="mytext">---->{{newText}}
</div>
</body>
<script>
var vm = new Vue({
el: '.app',
data: {
mytext: '',
},
methods: {
getUpper(){
return this.mytext.slice(0, 1).toUpperCase() + this.mytext.slice(1)
}
},
computed: {
newText(){
return this.mytext.slice(0, 1).toUpperCase() + this.mytext.slice(1)
}
}
})
</script>
</html>
6.1 通过计算属性重写过滤案例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div class="app">
<h1>过滤案例</h1>
<p>请输入要搜索的内容:<input type="text" v-model="myText"></p>
<ul>
<li v-for="item in newDateList">{{item}}</li>
</ul>
</div>
</body>
<script> var vm = new Vue({
el: '.app',
data: {
myText: '',
dataList: ['a', 'at', 'atom', 'be', 'beyond', 'cs', 'csrf'],
},
computed: {
newDateList() {
return this.dataList.filter(
item => item.indexOf(this.myText) >= 0
)
}
}
})</script>
</html>
7 监听属性
# 在data中定义了一些变量 只要变量发生变化 我们就执行一个函数
watch:{
// 监听这个数据 一旦发生变化(前面点击之后会变)
course_type(){
// 就会执行下边的方法
console.log('我变化了')
this.getData()
}
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="./js/vue.js"></script>
</head>
<body>
<div class="app">
<span @click="handleClick(1)">Python</span>|<span @click="handleClick(2)">Linux</span>
<div>
假设有很多课程 点击上面的标签可以完成过滤
</div>
</div>
</body>
<script>
var vm = new Vue({
el: '.app',
data: {
course_type: '0'
},
// 在创建之前执行一次 这次执行是默认0 表示获取所有
created(){
this.getDate()
},
methods: {
getData(){
// 发送ajax 获取所有课程 通过course过滤
},
handleClick(type){
// 通过点击事件改变course的数字来过滤课程内容 1表示python 2表示linux
this.course_type = type
this.getData()
}
},
watch:{
// 监听这个数据 一旦发生变化(前面点击之后会变)
course_type(){
// 就会执行下边的方法
console.log('我变化了')
this.getData()
}
}
})
</script>
</html>
node环境搭建
# Vue-CLI 项目搭建
-vue 脚手架 可以创建vue项目
# vue脚手架必须按照
-node js是一门后端语言
-JavaScript只能运行在浏览器中,因为浏览器中有他的解释器环境
-基于谷歌浏览器的v8引擎(js解释器),使它能够运行在操作系统上
-文件操作
-网络操作
-数据库操作 模块
-nodejs 解释器环境
-http://nodejs.cn/ 下载对应平台的nodejs解释器
-一路下一步安装
-安装完成会有两个可执行问题
python node
pip npm
-打开cmd
node 进入到了node环境
npm install 装模块