parent
f42eb51742
commit
287bc7dfc3
11 changed files with 178 additions and 38 deletions
@ -0,0 +1,20 @@ |
|||||||
|
<template> |
||||||
|
<div> |
||||||
|
<School/> |
||||||
|
<Student/> |
||||||
|
</div> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script> |
||||||
|
import School from "./components/School.vue"; |
||||||
|
import Student from "./components/Student.vue"; |
||||||
|
|
||||||
|
|
||||||
|
export default { |
||||||
|
name: "App", |
||||||
|
components: { |
||||||
|
School, |
||||||
|
Student |
||||||
|
} |
||||||
|
} |
||||||
|
</script> |
After Width: | Height: | Size: 6.7 KiB |
@ -0,0 +1,28 @@ |
|||||||
|
<template> |
||||||
|
<div> |
||||||
|
<h2 @click="showName">学校名称:{{ name }}</h2> |
||||||
|
<h2>学校地址:{{ address }}</h2> |
||||||
|
</div> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script> |
||||||
|
// 局部混合 |
||||||
|
// import {mixin_method1, mixin_method2} from "@/mixin"; |
||||||
|
|
||||||
|
export default { |
||||||
|
name: "School", |
||||||
|
data() { |
||||||
|
return { |
||||||
|
name: "修仙学院", |
||||||
|
address: "长白山", |
||||||
|
msg: "欢迎学校" // 以vc内数据为准 |
||||||
|
} |
||||||
|
}, |
||||||
|
mounted() { |
||||||
|
console.log("欢迎学校") // mixin和vc内的都要执行 |
||||||
|
}, |
||||||
|
// 局部混合 |
||||||
|
// mixins: [mixin_method1, mixin_method2] |
||||||
|
} |
||||||
|
</script> |
||||||
|
|
@ -0,0 +1,28 @@ |
|||||||
|
<template> |
||||||
|
<div> |
||||||
|
<h2 @click="showName">学生名称:{{ name }}</h2> |
||||||
|
<h2>学生年龄:{{ age }}</h2> |
||||||
|
</div> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script> |
||||||
|
// 局部混合 |
||||||
|
// import {mixin_method1, mixin_method2} from "../mixin"; |
||||||
|
|
||||||
|
export default { |
||||||
|
name: "Student", |
||||||
|
data() { |
||||||
|
return { |
||||||
|
name: "小强", |
||||||
|
age: 18, |
||||||
|
msg: "欢迎学生" |
||||||
|
} |
||||||
|
}, |
||||||
|
mounted() { |
||||||
|
console.log("欢迎学生") |
||||||
|
}, |
||||||
|
// 局部混合 |
||||||
|
// mixins: [mixin_method1, mixin_method2] |
||||||
|
} |
||||||
|
</script> |
||||||
|
|
@ -0,0 +1,16 @@ |
|||||||
|
import Vue from "vue"; |
||||||
|
import App from "./App"; |
||||||
|
|
||||||
|
import {mixin_method1, mixin_method2} from "@/mixin"; |
||||||
|
|
||||||
|
|
||||||
|
Vue.config.productionTip = false |
||||||
|
Vue.mixin(mixin_method1) |
||||||
|
Vue.mixin(mixin_method2) |
||||||
|
|
||||||
|
new Vue({ |
||||||
|
components: { |
||||||
|
App |
||||||
|
}, |
||||||
|
render: h => h(App) |
||||||
|
}).$mount('#app') |
@ -0,0 +1,17 @@ |
|||||||
|
export const mixin_method1 = { |
||||||
|
methods: { |
||||||
|
showName() { |
||||||
|
alert(this.name) |
||||||
|
} |
||||||
|
}, |
||||||
|
mounted() { |
||||||
|
console.log("欢迎") |
||||||
|
} |
||||||
|
} |
||||||
|
export const mixin_method2 = { |
||||||
|
data() { |
||||||
|
return { |
||||||
|
msg: "欢迎" |
||||||
|
} |
||||||
|
} |
||||||
|
} |
@ -1,15 +1,19 @@ |
|||||||
<template> |
<template> |
||||||
<div> |
<div> |
||||||
<Student name="小强" sex="男" :age="18"/> |
<School/> |
||||||
|
<Student/> |
||||||
</div> |
</div> |
||||||
</template> |
</template> |
||||||
|
|
||||||
<script> |
<script> |
||||||
|
import School from "./components/School.vue"; |
||||||
import Student from "./components/Student.vue"; |
import Student from "./components/Student.vue"; |
||||||
|
|
||||||
|
|
||||||
export default { |
export default { |
||||||
name: "App", |
name: "App", |
||||||
components: { |
components: { |
||||||
|
School, |
||||||
Student |
Student |
||||||
} |
} |
||||||
} |
} |
||||||
|
@ -0,0 +1,28 @@ |
|||||||
|
<template> |
||||||
|
<div> |
||||||
|
<h2 @click="showName">学校名称:{{ name }}</h2> |
||||||
|
<h2>学校地址:{{ address }}</h2> |
||||||
|
</div> |
||||||
|
</template> |
||||||
|
|
||||||
|
<script> |
||||||
|
// 局部混合 |
||||||
|
// import {mixin_method1, mixin_method2} from "@/mixin"; |
||||||
|
|
||||||
|
export default { |
||||||
|
name: "School", |
||||||
|
data() { |
||||||
|
return { |
||||||
|
name: "修仙学院", |
||||||
|
address: "长白山", |
||||||
|
msg: "欢迎学校" // 以vc内数据为准 |
||||||
|
} |
||||||
|
}, |
||||||
|
mounted() { |
||||||
|
console.log("欢迎学校") // mixin和vc内的都要执行 |
||||||
|
}, |
||||||
|
// 局部混合 |
||||||
|
// mixins: [mixin_method1, mixin_method2] |
||||||
|
} |
||||||
|
</script> |
||||||
|
|
@ -1,53 +1,28 @@ |
|||||||
<template> |
<template> |
||||||
<div> |
<div> |
||||||
<h1>{{ msg }}</h1> |
<h2 @click="showName">学生名称:{{ name }}</h2> |
||||||
<h2>学生名称:{{ name }}</h2> |
<h2>学生年龄:{{ age }}</h2> |
||||||
<h2>学生性别:{{ sex }}</h2> |
|
||||||
<h2>学生年龄:{{ localAge + 1 }}</h2> |
|
||||||
<button @click="changeAge">点击年龄+1</button> |
|
||||||
</div> |
</div> |
||||||
</template> |
</template> |
||||||
|
|
||||||
<script> |
<script> |
||||||
|
// 局部混合 |
||||||
|
// import {mixin_method1, mixin_method2} from "../mixin"; |
||||||
|
|
||||||
export default { |
export default { |
||||||
name: "Student", |
name: "Student", |
||||||
data() { |
data() { |
||||||
return { |
return { |
||||||
msg: "欢迎", |
name: "小强", |
||||||
localAge: this.age |
age: 18, |
||||||
|
msg: "欢迎学生" |
||||||
} |
} |
||||||
}, |
}, |
||||||
methods: { |
mounted() { |
||||||
changeAge() { |
console.log("欢迎学生") |
||||||
this.localAge++ |
|
||||||
} |
|
||||||
}, |
}, |
||||||
|
// 局部混合 |
||||||
// 数组形式 |
// mixins: [mixin_method1, mixin_method2] |
||||||
// props: ['name', 'age', 'sex'] |
|
||||||
|
|
||||||
// 简单对象形式(限定数据类型) |
|
||||||
// props: { |
|
||||||
// name: String, |
|
||||||
// age: Number, |
|
||||||
// sex: String |
|
||||||
// } |
|
||||||
|
|
||||||
// 完全对象形式 |
|
||||||
props: { |
|
||||||
name: { |
|
||||||
type: String, |
|
||||||
required: true, |
|
||||||
}, |
|
||||||
age: { |
|
||||||
type: Number, |
|
||||||
default: 99 |
|
||||||
}, |
|
||||||
sex: { |
|
||||||
type: String, |
|
||||||
required: true |
|
||||||
} |
|
||||||
} |
|
||||||
} |
} |
||||||
</script> |
</script> |
||||||
|
|
||||||
|
@ -0,0 +1,17 @@ |
|||||||
|
export const mixin_method1 = { |
||||||
|
methods: { |
||||||
|
showName() { |
||||||
|
alert(this.name) |
||||||
|
} |
||||||
|
}, |
||||||
|
mounted() { |
||||||
|
console.log("欢迎") |
||||||
|
} |
||||||
|
} |
||||||
|
export const mixin_method2 = { |
||||||
|
data() { |
||||||
|
return { |
||||||
|
msg: "欢迎" |
||||||
|
} |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue