<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<label v-for="item in beautyGirls" :for="item">
<input type="checkbox" :value="item"
:id="item" v-model="girls">{{item}}
</label>
<h3>您的选择是:{{girls}}</h3>
</div>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '你好',
girls: [],//多选框
beautyGirls: ["云韵","比比东","雅妃","纳兰嫣然","美杜莎"]
}
})
</script>
</body>
</html>
登入後複製
#7、v-model修飾符的使用 <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<!-- lazy懒加载,失去焦点时触发 -->
<input type="text" v-model.lazy="message">
<h2>{{message}}</h2>
<!-- number:表示数字类型 -->
<input type="number" v-model.number="age">
<h2>{{age}} --> {{typeof age}}</h2>
<!-- 去掉左右两边的控股 -->
<input type="text" v-model.trim="name">
<h2>{{name}}</h2>
</div>
<script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '哪吒',
age: 0,
name: '哪吒'
}
})
</script>
</body>
</html>
登入後複製
三、元件化開發- 元件是Vue.js中重要想法
-
它提供了一種抽象, 我們可以發展出一個獨立可複用的小元件來建構我們的應用元件可以擴充HTML 元素,封裝可重複使用的程式碼
元件系統讓我們可以用獨立可重複使用的小元件來建構大型應用,幾乎任意類型的應用的介面都可以抽象化為一個元件樹
元件化思想應用
有了元件化的想法, 我們之後開發中就要充分的利用它
盡可能將頁面拆分成一個個小的, 可復用的組件
這樣讓我們代碼更方便組織和管理, 並且擴展性也強### #########1、全域元件######<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<my-cpn></my-cpn>
</div>
<script src="../js/vue.js"></script>
<script>
//1.创建组件化构造器对象
const cpnC = Vue.extend({
template: `
<div>
<h2>我是标题</h2>
<p>我是CSDN哪吒</p>
</div>
`
})
//2.注册组件
Vue.component('my-cpn',cpnC)
const app = new Vue({
el: '#app',
data: {
message: '你好'
}
})
</script>
</body>
</html>
登入後複製
###2、局部元件###<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<cpn></cpn>
</div>
<script src="../js/vue.js"></script>
<script>
//1.创建组件化构造器对象
const cpnC = Vue.extend({
template: `
<div>
<h2>我是标题</h2>
<p>我是CSDN哪吒</p>
</div>
`
})
const app = new Vue({
el: '#app',
data: {
message: '你好'
},
components: {
cpn: cpnC
}
})
</script>
</body>
</html>
登入後複製
############3、父子元件### <!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<cpn2></cpn2>
</div>
<script src="../js/vue.js"></script>
<script>
//1.创建组件化构造器对象
const cpnC1 = Vue.extend({
template: `
<div>
<h2>我是标题1</h2>
<p>我是CSDN哪吒</p>
</div>
`
})
const cpnC2 = Vue.extend({
template: `
<div>
<h2>我是标题2</h2>
<p>我是博客专家</p>
<cpn1></cpn1>
</div>
`,
components: {
cpn1: cpnC1
}
})
const app = new Vue({
el: '#app',
data: {
message: '你好'
},
components: {
cpn2: cpnC2
}
})
</script>
</body>
</html>
登入後複製
#########4、组件化语法糖写法
vue为了简化注册组件的过程,提供了语法糖的写法,主要是省去了调用Vue.extend()的步骤,直接使用一个对象替代。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<my-cpn></my-cpn>
</div>
<script src="../js/vue.js"></script>
<script>
//注册组件语法糖写法
Vue.component('my-cpn',{
template: `
<div>
<h2>我是标题</h2>
<p>我是CSDN哪吒</p>
</div>
`
})
const app = new Vue({
el: '#app',
data: {
message: '你好'
}
})
</script>
</body>
</html>
登入後複製
5、组件模板抽离写法
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<cpn></cpn>
<cpn></cpn>
<cpn></cpn>
</div>
<!--1.script标签, 注意:类型必须是text/x-template-->
<!--<script type="text/x-template" id="cpn">-->
<!--<div>-->
<!--<h2>我是标题</h2>-->
<!--<p>我是CSDN哪吒</p>-->
<!--</div>-->
<!--</script>-->
<!--2.template标签-->
<template id="cpn">
<div>
<h2>我是标题</h2>
<p>我是CSDN哪吒</p>
</div>
</template>
<script src="../js/vue.js"></script>
<script>
// 1.注册一个全局组件
Vue.component('cpn', {
template: '#cpn'
})
const app = new Vue({
el: '#app',
data: {
message: '你好啊'
}
})
</script>
</body>
</html>
登入後複製
四、组件可以访问Vue实例数据吗?
1、简介
实验发现,组件不能访问Vue实例数据,而且即便可以访问,如果将所有的数据都放在Vue实例中,Vue实例就会变得非常臃肿。
Vue组件应该有自己保存数据的地方。
组件自己的数据存放在哪里?
- 组件对象也有一个data属性(也有method等属性);
- 只是这个data属性必须是一个函数;
- 而且这个函数返回一个对象,对象内部保存着数据;
2、代码实例
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<cpn></cpn>
</div>
<template id="cpn">
<div>
<h2>{{title}}</h2>
<p>我是热门</p>
</div>
</template>
<script src="../js/vue.js"></script>
<script>
// 1.注册一个全局组件
Vue.component('cpn', {
template: '#cpn',
data() {
return {
title: '哪吒必胜'
}
}
})
const app = new Vue({
el: '#app',
data: {
message: '你好',
// title: '我是标题'
}
})
</script>
</body>
</html>
登入後複製
3、效果展示
五、父子组件通信
1、父子组件通信简介
在开发中,往往一些数据确实需要从上层传递到下层:
比如在一个页面中,我们从服务器请求到了很多的数据。
其中一部分数据,并非是我们整个页面的大组件来展示的,而是需要下面的子组件进行展示。
这个时候,并不会让子组件再次发送一个网络请求,而是直接让大组件(父组件)将数据传递给小组件(子组件)。
如何进行父子组件间的通信呢?Vue官方提到:
通过props向子组件传递数据
通过事件向父组件发送消息
在组件中,使用选项props来声明需要从父级接收到的数据。
props的值有两种方式:
方式一:字符串数组,数组中的字符串就是传递时的名称。
方式二:对象,对象可以设置传递时的类型,也可以设置默认值等。
2、父传子代码实例
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<!--<cpn v-bind:cgirls="girls"></cpn>-->
<!--<cpn cgirls="girls" cmessage="message"></cpn>-->
<cpn :cmessage="message" :cgirls="girls"></cpn>
</div>
<template id="cpn">
<div>
<ul>
<li v-for="item in cgirls">{{item}}</li>
</ul>
<h2>{{cmessage}}</h2>
</div>
</template>
<script src="../js/vue.js"></script>
<script>
// 父传子: props
const cpn = {
template: '#cpn',
// props: ['cgirls', 'cmessage'],
props: {
// 1.类型限制
// cgirls: Array,
// cmessage: String,
// 2.提供一些默认值, 以及必传值
cmessage: {
type: String,
default: 'aaaaaaaa',
required: true
},
// 类型是对象或者数组时, 默认值必须是一个函数
cgirls: {
type: Array,
default() {
return []
}
}
},
data() {
return {}
},
methods: {
}
}
const app = new Vue({
el: '#app',
data: {
message: 'CSDN哪吒',
girls: ['云韵', '比比东', '雅妃']
},
components: {
cpn
}
})
</script>
</body>
</html>
登入後複製
3、父传子效果展示
4、props中的驼峰标识
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<div id="app">
<cpn :c-info="info" :child-my-message="message" v-bind:class></cpn>
</div>
<template id="cpn">
<div>
<h2>{{cInfo}}</h2>
<h2>{{childMyMessage}}</h2>
</div>
</template>
<script src="../js/vue.js"></script>
<script>
const cpn = {
template: '#cpn',
props: {
cInfo: {
type: Object,
default() {
return {}
}
},
childMyMessage: {
type: String,
default: ''
}
}
}
const app = new Vue({
el: '#app',
data: {
info: {
name: '哪吒',
age: 18,
height: 1.88
},
message: 'csdn博客专家'
},
components: {
cpn
}
})
</script>
</body>
</html>
登入後複製
效果展示
5、子传父(自定义事件方式)
自定义事件方式完成子传父。
什么时候需要自定义事件呢?
当子组件需要向父组件传递数据时,就要用到自定义事件了。
我们之前学习的v-on不仅仅可以用于监听DOM事件,也可以用于组件间的自定义事件。
自定义事件的流程:
在子组件中,通过$emit()来触发事件。
在父组件中,通过v-on来监听子组件事件。
6、子传父代码实例
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<!--父组件模板-->
<div id="app">
<cpn @item-click="cpnClick"></cpn>
</div>
<!--子组件模板-->
<template id="cpn">
<div>
<button v-for="item in categories"
@click="btnClick(item)">
{{item.name}}
</button>
</div>
</template>
<script src="../js/vue.js"></script>
<script>
// 1.子组件
const cpn = {
template: '#cpn',
data() {
return {
categories: [
{id: '1', name: '云韵'},
{id: '2', name: '比比东'},
{id: '3', name: '雅妃'},
{id: '4', name: '纳兰嫣然'},
]
}
},
methods: {
btnClick(item) {
// 发射事件: 自定义事件
this.$emit('item-click', item)
}
}
}
// 2.父组件
const app = new Vue({
el: '#app',
data: {
message: 'csdn哪吒'
},
components: {
cpn
},
methods: {
cpnClick(item) {
console.log('cpnClick', item);
}
}
})
</script>
</body>
</html>
登入後複製
7、子传父效果展示
【相关推荐:javascript视频教程、web前端】
以上是Vue基礎知識總結之vue組件化開發的詳細內容。更多資訊請關注PHP中文網其他相關文章!