vue系统总结2
<div id="app">
<mycpn></mycpn>
</div>
<script src="../js/vue.js"></script>
<script>
//1.创建组件构造器对象
const cpn = Vue.extend({
template: `
<div>
<h2>我是标题</h2>
<p>我是内容,哈哈哈哈</p>
<p>我是内容,呵呵呵呵呵呵</p>
</div>`
}) Vue.component('mycpn',cpn) const app = new Vue({
el: '#app',
data: { }
})
</script>
<div id="app">
<mycpn></mycpn>
<cpn></cpn>
</div>
<script src="../js/vue.js"></script>
<script>
//1.创建组件构造器
const cpn = Vue.extend({
template: `
<div>
<h2>我是标题1</h2>
<p>我是内容 哈哈哈哈</p>
</div>
`
})
// 2.注册组件(全局组件,意味着可以再多个vue实例中使用)
Vue.component('mycpn',cpn) const app = new Vue({
el: '#app',
data: {
message: '你好啊'
},
components: {
cpn:cpn
}
})
</script>
<div id="app">
<cpn2></cpn2>
<h2>--------</h2>
<cpn1></cpn1>
</div> <script src="../js/vue.js"></script> <script>
// 1.创建第一个组件构造器
const cpn1 = Vue.extend({
template: `<div>
<h2>我是子组件标题</h2>
<p>我是子组件内容 哈哈哈</p>
</div>`
}) //2.创建第二个组件构造器
const cpn2 = Vue.extend({
template:`<div>
<h2>我是父组件标题</h2>
<p>我是父组件内容 呵呵呵呵呵</p>
<cpn1></cpn1>
</div>`,
//在组件内部使用带s的components
components:{
cpn1: cpn1
}
})
const app = new Vue({
el:'#app',
data:{
},
components:{
cpn2: cpn2,
cpn1: cpn1
}
})
</script>
<div id="app">
<cpn></cpn>
</div>
<script src="../js/vue.js"></script>
<script> //一.全局组件注册的语法糖
//1.创造组件构造器
// const cpn1 = Vue.extend() //2.注册组件
// Vue.component('cpn',{
// template: `<div>
// <h2>我是全局组件标题</h2>
// <p>我是全局组件内容 呵呵呵呵呵</p>
// </div>`
// }) const app = new Vue({
el: '#app',
data: {
},
components:{
cpn: {
template: `<div>
<h2>我是局部组件标题</h2>
<p>我是局部组件内容 呵呵呵呵呵</p>
</div>`
}
}
})
</script>
<div id="app">
<cpn></cpn>
<cpn></cpn>
<cpn></cpn>
</div> <!-- 第一种模板 注意:必须是text/x-template类型-->
<!-- <script type="text/x-template" id="cpn">
<div>
<h2>我是标题</h2>
<p>我是内容</p>
</div>
</script> --> <!-- 第二种模板:template -->
<template id="cpn">
<div>
<h2>这是标题哈哈</h2>
<p>这是内容哈哈</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>
<div id="app">
<cpn></cpn>
<cpn></cpn>
<cpn></cpn>
</div> <!-- 第一种模板 注意:必须是text/x-template类型-->
<!-- <script type="text/x-template" id="cpn">
<div>
<h2>我是标题</h2>
<p>我是内容</p>
</div>
</script> --> <!-- 第二种模板:template -->
<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: '你好啊'
}
})
</script>
<div id="app">
<cpn></cpn>
<cpn></cpn>
<cpn></cpn>
</div>
<template id="cpn">
<div>
<h2>当前计数是 : {{counter}}</h2>
<button @click='innerment'>+</button>
<button @click='denerment'>-</button>
</div>
</template>
<script src="../js/vue.js"></script>
<script> Vue.component('cpn',{
template: '#cpn',
data () {
return {
counter: 0
}
},
methods:{
innerment(){
this.counter++
},
denerment(){
this.counter--
},
}
}) const app = new Vue({
el: '#app',
data: {
message: '你好啊'
}
})
</script>
<body>
<div id="app">
<!-- 使用cpn子组件 动态绑定movies和message -->
<cpn :cmovies="movies" :cmessage="message"></cpn>
</div> <!-- 子组件模板 -->
<template id="cpn">
<div>
<ul>
<!-- 循环cmovies的电影 -->
<li v-for="item in cmovies">{{item}}</li>
</ul>
<h2>{{cmessage}}</h2>
</div>
</template>
<!-- 引入vue文件 -->
<script src="../js/vue.js"></script>
<script>
//实例化子组件
const cpn = {
//模板对象,和el挂载点相似,注意:template必须要有id为cpn的
template: '#cpn',
//子组件data必须是一个函数,每个组件调用的时候不能是同一个对象,
//只能是一个函数,必须带有return返回值
data(){
return {}
},
methods:{},
//父组件向子组件传递信息使用props方法
props:{
cmovies:{
type:Array,
default(){
return []
},
required: true
},
cmessage: {
type:String,
default: 'aaaa',
required: true
}
}
} //根组件,也可以算父组件,实例化vue对象
const app = new Vue({
//挂载点:#app
el: '#app',
//对象中数据现在不用函数
data: {
message: '测试文件',
movies:['肖申克的救赎','当幸福来敲门','加勒比海盗','了不起的盖茨比']
},
//注册组件
components:{
cpn
}
})
</script>
<div id="app">
<cpn @itembtn="cpnclick"></cpn>
</div> <template id="cpn">
<div>
<button v-for="item in categories"
@click="itemclick(item)">{{item.name}}</button>
</div>
</template> <script src="../js/vue.js"></script>
<script>
const cpn = {
template: '#cpn',
data () {
return {
categories: [
{id: 'aaa',name: '打开应用'},
{id: 'bbb',name: '获取应用'},
{id: 'ccc',name: '新建应用'},
{id: 'ddd',name: '保存应用'},
{id: 'eee',name: '关闭应用'},
]
}
},
methods: {
itemclick (item) {
console.log(item.id)
this.$emit('itembtn',item)
}
}
} const app = new Vue({
el: '#app',
data: {
message: '你好啊'
},
components: {
cpn
},
methods:{
cpnclick (item) {
console.log(item.id)
}
}
})
</script>
<div id="app">
<cpn ref="ccc"></cpn>
<cpn ref="bbb"></cpn>
<cpn ref="aaa"></cpn>
<button @click='btnClick'>测试按钮</button>
</div> <template id="cpn">
<div>
<h2>我是子组件</h2>
</div>
</template> <script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '你好啊'
},
methods: {
btnClick() {
//1$children 用法比较少 是获取全部的自组件里面方法
// console.log(this.$children)
// // this.$children[0].showMessage()
// for(let c of this.$children){
// c.showMessage()
// console.log(c.name)
// } //2 $refs 用的最多 注意此处写的 是refs ,上面写的是ref=""
// $refs => 对象类型 ,默认是一个空的对象 如果使用上面要用 ref="bbb"
console.log(this.$refs.aaa.name)
this.$refs.aaa.showMessage()
console.log(this.$refs.bbb.name)
this.$refs.bbb.showMessage()
console.log(this.$refs.ccc.name)
this.$refs.ccc.showMessage() }
},
components: {
cpn: {
template: '#cpn',
data() {
return {
name: `中级的欲望 通过努力可以获得
低级的欲望 通过放纵可以获得`
}
},
methods: {
showMessage() {
console.log('顶级的欲望 通过煎熬才能获得')
}
}
}
}
})
</script>
<div id="app">
<h2>这是vue实例</h2>
<cpn></cpn>
</div> <template id="cpn">
<div>
<h2>这是自组件</h2>
<ccpn></ccpn>
</div>
</template> <template id="ccpn">
<div>
<h2>我是子组件内部组件</h2>
<button @click="btnClick">点击按钮</button>
</div>
</template> <script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: '你好啊'
},
components: {
cpn: {
template: '#cpn',
data(){
return {
name: `
低级的欲望 通过放纵就可获得
高级的欲望 通过自律方可获得
顶级的欲望 通过骄傲才可获得`
}
},
components: {
ccpn: {
template: '#ccpn',
methods: {
btnClick() {
//1第一种 $parent 只能访问父级组件的数据,但是耦合性很高,不能扩展
// console.log(this.$parent)
// console.log(this.$parent.name) //2第二种,通过root 获取根组件的数据
console.log(this.$root)
console.log(this.$root.message)
}
}
}
}
}
}
})
</script>
<div id="app">
<cpn>
<span>姓名</span>
<input type="text" name='username' placeholder="请输入姓名">
</cpn>
<cpn>
<span>密码</span>
<input type="text" name="password" placeholder="请输入密码">
</cpn>
<cpn>
<button>登录</button>
<button>注册</button>
</cpn>
</div> <template id="cpn">
<div>
<!-- <h2>使用slot</h2>
<button>slot</button> -->
<slot>
<button>初始按钮</button>
</slot>
</div>
</template> <script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: 'hell Vue.js'
},
components: {
cpn: {
template: '#cpn',
data() {
return {}
},
methods:{}
}
}
})
</script>
<div id="app">
<cpn>
<button slot="left">返回</button>
</cpn>
<cpn>
<span slot="left">姓名</span>
<input type="text" slot="center" placeholder="请输入姓名">
</cpn>
<cpn>
<span slot="left">密码</span>
<input type="text" slot="center" placeholder="请输入密码">
</cpn>
<cpn>
<button slot="left">登录</button>
<button slot="right">注册</button>
</cpn>
</div> <template id="cpn">
<div>
<slot name="left"></slot>
<slot name="center"></slot>
<slot name="right"></slot>
<slot name="noname"></slot>
</div>
</template> <script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: 'hello Vue.js'
},
components:{
cpn: {
template: '#cpn',
methods:{},
data() {
return {}
},
props:{},
computed:{}
}
}
})
</script>
<div id="app">
<cpn v-show="isShow"></cpn>
</div> <template id="cpn">
<div>
<h2>我是子组件</h2>
<h3>你有为自己努力过吗</h3>
<button v-show="isShow"></button>
</div>
</template> <script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: 'hello Vue.js',
isShow: true
},
components: {
cpn: {
template: '#cpn',
props:{},
methods:{},
data () {
return {
isShow: false
}
}
} }
})
</script>
<div id="app">
<cpn></cpn>
<cpn>
<span slot="aaa">测试文件</span>
</cpn>
<cpn>
<div slot="aaa" slot-scope="slot">
<span v-for="item in slot.data">{{item}} -</span>
</div>
</cpn>
<cpn>
<div slot="aaa" slot-scope="slot">
<span v-for="item in slot.data">{{item}} $</span>
</div>
</cpn>
<cpn>
<div slot="aaa" slot-scope='slot'>
<!-- <span v-for="item in slot.data">{{item}}</span> -->
<span>{{slot.data.join('--')}}</span>
</div>
</cpn>
</div> <template id="cpn">
<div>
<slot name='aaa' :data="pLanges">
<ul>
<li v-for="item in pLanges">{{item}}</li>
</ul>
</slot>
</div>
</template> <script src="../js/vue.js"></script>
<script>
const app = new Vue({
el: '#app',
data: {
message: 'hello Vue.js'
},
components:{
cpn: {
template: '#cpn',
data() {
return {
pLanges: ['C++','python','java','js','php']
}
}
}
}
})
</script>
vue系统总结2的更多相关文章
- 一天带你入门到放弃vue.js(一)
写在前面的话! 每个新的框架入手都会进行一些列的扯犊子!这里不多说那么多!简简单单说一下vue吧! Vue.js是目前三大框架(angular,vue,react)之一,是渐进式js框架,据说是摒弃了 ...
- vue 后台管理系统菜单权限管理
来自:https://www.cnblogs.com/fqh123/p/11094296.html 侵删 login登录方法 login() { if (!this.username) { retur ...
- vue自定义指令实例使用(实例说明自定义指令的作用)
在写vue项目的时候,我们经常需要对后台返回的数据进行大量的渲染操作,其中就包含了大量的对特殊数据的进一步处理,比如说时间戳.图片地址.特殊数据显示等等特殊数据处理改进. 其实遇到这种情况,通过Vue ...
- React技术实践(1)
随着系统越来越庞大,前端也变得越来越复杂,因此,构建一套组件化的前端变得很重要了. 之前一直在使用Asp.net来进行前端的组件化,Asp.net组件化有个很大的缺陷,就是和后台代码绑定太紧密了,不符 ...
- 若依管理系统RuoYi-Vue(二):权限系统设计详解
若依Vue系统中的权限管理部分的功能都集中在了系统管理菜单模块中,如下图所示.其中权限部分主要涉及到了用户管理.角色管理.菜单管理.部门管理这四个部分. 一.若依Vue系统中的权限分类 根据观察,若依 ...
- 若依管理系统RuoYi-Vue(三):代码生成器原理和实战
历史文章 若依管理系统RuoYi-Vue(一):项目启动和菜单创建 若依管理系统RuoYi-Vue(二):权限系统设计详解 本篇文章将会讲解ruoyi-vue系统下代码生成器的使用.原理分析以及将这部 ...
- 2012高校GIS论坛
江苏省会议中心 南京·钟山宾馆(2012年4月21-22日) 以"突破与提升"为主题的"2012高校GIS论坛"将于4月在南京举行,由南京大学和工程中心共同承办 ...
- 一个 Vue + Node + MongoDB 博客系统
源码 耗时半载(半个月)的大项目终于完成了.这是一个博客系统,使用 Vue 做前端框架,Node + express 做后端,数据库使用的是 MongoDB.实现了用户注册.用户登录.博客管理(文章的 ...
- 【Vue】Vue的依赖追踪系统 ——搞懂methods watch和compute
从作用机制和性质上看待methods,watch和computed的关系 <他三个是啥子关系呢?> 首先要说,methods,watch和computed都是以函数为基础的,但各自却都不同 ...
随机推荐
- webrtc编译
webrtc编译 最近研究 libmediasoupclient,而 libmediasoupclient 又依赖 libwebrtc,所以首先就想着先在windows上编译一个webrtc的库,先是 ...
- DOS命令--Windows操作系统之母
DOS命令 DOS是什么 解释:Disk Operating System的缩写,意思是"磁盘操作系统" 系统:DOS就是人给机器下达命令的集合,是存储在操作系统中的命令集 基本用 ...
- 自学linux——2.认识目录及常用指(命)令
认识目录及常用指(命)令 1.备份: 快照(还原精灵):短期备份 频繁备份 可关可开.可能会影响系统的操作. 备份时:虚拟机--快照 还原时:虚拟机--快照--快照管理器--相应位置--转到 克隆 ...
- openssl not found 离线安装的openssl问题
离线安装问题 正常我们在Linux中按照 nginx的openssl依赖都是通过 yum来安装的,但是由于一些特殊的服务器公司不让服务器连接互联网,所以就导致我们必须通过离线方式来进行安装,但是我们离 ...
- 随着日益增多的新技术,Android开发接下来的路该怎么走?
很多小伙伴们经常问我android移动开发者的走向,一部分人都想多快好省,间歇性踌躇满志.持续性混吃等死 ,只想用CV的开发模式们快速完成工作,然后回家王者农药.其实这种现象很普遍,我想告诉你的是 , ...
- TestNG注释@BeforeGroups与@AfterGroups不执行的处理
在学习TestNG框架注解时发现在执行以下的代码 package com.groups; import org.testng.annotations.AfterGroups; import org.t ...
- MapReduce框架原理-Writable序列化
序列化和反序列化 序列化就是把内存中的对象,转换成字节序列(或其他数据传输协议)以便于存储(持久化)和网络传输. 反序列化就是将收到字节序列(或其他数据传输协议)或者是硬盘的持久化数据,转换成内存中的 ...
- js中判断数据类型的四种方法总结
js中判断数据类型的四种方法 前言 在js中,我们经常需要判断数据的类型,那么哪些方法可以用来判断数据的类型呢?哪种方法判断数据类型最准确呢? 我们来一个个分析: 1.typeof typeof是一个 ...
- MobSF移动安全扫描平台环境搭建与试用
MobSF简介 MobSF(Mobile-Security-Framework)是一种开源自动化的移动应用程序(Android / iOS / Windows)安全测试框架,能够执行静态,动态和恶意软 ...
- TotalCommander的两款目录插件
CatalogMaker 与 DiskDir Extended 是两个用于生成文件夹目录的totalCmd插件. 将指定目录下所有文件.文件夹以指定格式存储在一个文本文件中,可作为EverCD+的轻量 ...