组件间通信

组件其他

根组件和组件一些问题
	-new Vew()--->管理div---》根组件
    -自己再定义的全局,局部是组件
    -组件有自己的html,css,js---》数据,事件。。。
    -在组件中,this代指当前组件
    -父子组件的data是无法共享的
    -data是1个函数,需要有返回值(return)

组件间通信之父传子

组件间数据不共享---》需要进行数据传递

父传子:使用自定义属性方式

前端代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="/js/vue.js"></script>
</head>
<body>
<div id="app">
        <h1>父子通信之父传子,通过自定义属性--->不能用驼峰体,也不要跟组件的变量名冲突</h1>
    <child :age="age" ></child>
</div>
</body>

<script>
    //写一个组件
    var child = {
        template:`
           <div>
        <button>后退</button>
        首页---名字:{{myname}}--->年龄:{{age}}
        <button>前进</button>
</div>
        `,
        data(){
            return {myname:'lqz'}
        },
        props:{age:Number}
    }
    var vm = new Vue({
        el: '#app',
        data: {age: 19,name:'彭于晏'},
        //下面是注册组件
        components:{
            child
        }
    })


</script>
</html>

组件间通信之子传父

image-20230217103331749

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="/js/vue.js"></script>
</head>
<body>

<div id="app">
    <p>子组件传递过来的数据:{{mytext}}</p>
    <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() {
                // alert(this.mytext)
                //子组件中,触发自定义事件的执行,会执行父组件自定义事件绑定的函数,有几个参数,就传几个参数
                this.$emit('myevent',this.mytext)
            }
        }
    }
    var vm = new Vue({
        el: '#app',
        data: {mytext: ''},
        methods: {handleEvent(mytext){
            this.mytext=mytext
            }},
        components: {
            child
        }
    })
</script>

</html>

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 id="app">
    <button @click="handerClick">值</button>
    ---{{age}}
    <p>子组件传递过来的数据</p>
    <child ref="mychild"></child>
</div>

</body>

<script>
    //子组件
    var child = {
        template: `
          <div>
          <input type="text">
          <p>名字:{{name}}</p>
          </div>
        `,
        data() {
            return {age:18,name:'刘亦菲'}
        },
    }
    var vm = new Vue({
        el: '#app',
        data: {age: '',name:'彭于晏'},
        methods: {handerClick(){
            //这个是子传父,拿到父组件的age属性修改为子组件的age
            this.age=this.$refs.mychild.age
            //这个是父传子,拿到子组件的name属性修改为父组件的name
      //重点:以后就不需要关注是子传父还是父传子了,直接通过对象取值赋值即可,而且可以主动调用子组件中的函数
            this.$refs.mychild.name=this.name
            }
            },
        components: {
            child
        }
    })
</script>

</html>

动态组件

不使用动态组件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="/js/vue.js"></script>
</head>
<body>
<div id="app">
    <span @click="handerClick('home')">首页</span> <span @click="handerClick('order')">订单</span> <span
        @click="handerClick('goods')">商品</span>
    <home v-if="choiceType=='home'"></home>
    <order v-else-if="choiceType=='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: {choiceType: 'home'},
        methods: {
            handerClick(type) {
                this.choiceType = type
            }
        },
        components: {home, order, goods}
    })
</script>


</html>

动态组件,component标签

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="/js/vue.js"></script>
</head>
<body>
<div id="app">
    <span @click="handerClick('home')">首页</span> <span @click="handerClick('order')">订单</span> <span
        @click="handerClick('goods')">商品</span>
    <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: {
            handerClick(type) {
                this.who = type
            }
        },
        components: {home, order, goods}
    })
</script>


</html>

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>

插槽

<!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="./img.png" alt="">

        </div>
        
    </home>
    <hr>

</div>

</body>
<script>

    var home = {
        template: `
          <div>
          <h1>home页面</h1>
            <slot></slot>
            <h1>结束了</h1>
          </div>`,

    }
    var vm = new Vue({
        el: '.app',
        data: {},
        components: {
            home,
        }


    })
</script>
</html>

具名插槽

<!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">
            <img src="./img.png" alt="">

        </div>

        <div slot="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>
          </div>`,

    }
    var vm = new Vue({
        el: '.app',
        data: {},
        components: {
            home,
        }


    })
</script>
</html>

计算属性

计算属性只有使用的变量发生变化时,才重新运算
计算属性就想python中的property,可以把方法/函数伪装成属性

计算属性基本使用

<!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">&#45;&#45;&ndash;&gt;{{mytext.slice(0, 1).toUpperCase() + mytext.slice(1)}}-->


    <h1>input输入单词,首字母转成大写展示---函数方式---》只要页面刷新,无论跟它有没有关,都会重新运算</h1>
    <!--    <input type="text" v-model="mytext">&#45;&#45;&ndash;&gt;{{getUpper()}}-->
    <input type="text" v-model="mytext">---->{{newText}}

    <br>
    <input type="text" v-model="age">--->{{age}}

</div>

</body>
<script>

    var vm = new Vue({
        el: '.app',
        data: {
            mytext: '',
            age: 10
        },
        methods: {
            getUpper() {
                console.log('函数---我执行了')
                return this.mytext.slice(0, 1).toUpperCase() + this.mytext.slice(1)
            }
        },
        // 计算属性---->computed 里面写方法,以后,方法当属性用 ,一定要有return值
        computed: {
            newText() {
                console.log('计算属性---我执行了')
                return this.mytext.slice(0, 1).toUpperCase() + this.mytext.slice(1)
            }
        }


    })
</script>
</html>

通过计算属性重写过滤案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div>
    <div class="app">
        <h1>过滤案例</h1>
        <p>请输入要搜索的内容:<input type="text" v-model="myText"></p>
        <ul>
            <li v-for="item in newDateList">{{item}}</li>
        </ul>

    </div>

</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
                )
            }
        }

    })

监听属性

在data中定义一些变量,只要变量发生变化,我们就执行一个函数

watch:{
    属性名(){}
}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./js/vue.js"></script>
</head>
<body>
<div>
    <div class="app">
        <!--        <span @click="handleClick(1)">Python</span>|    <span @click="handleClick(2)">Linux</span>-->
        <span @click="course_type=1">Python</span>| <span @click="course_type=2">Linux</span>
        <div>
            假设有很多课程,点击上面的标签可以完成过滤
        </div>

    </div>

</div>
</body>
<script>
    var vm = new Vue({
        el: '.app',
        data: {
            course_type: '0'
        },
        created() {
            this.getData()
        },
        methods: {
            getData() {
                // 发送ajax ,获取所有课程,通过course过滤
                // http://127.0.0.1:8080/api/v1/courses?course_type=0
            },
            // handleClick(type){
            //     this.course_type=type
            //     this.getData()
            // }
        },
        watch: {
            course_type() {
                console.log('我变化了')
                this.getData()
            }
        }

    })


</script>
</html>

node环境搭建

# Vue-CLI 项目搭建
	-vue 脚手架  可以创建vue项目
    
    
# vue脚手架必须要按照 node js   解释型语言
	-node js是一门后端语言
    -JavaScript只能运行在浏览器中,因为浏览器中有他的解释器环境
    -基于谷歌浏览器的v8引擎(js解释器),使它能够运行在操作系统上
    	-文件操作
        -网络操作
        -数据库操作  模块
        
        
        
   -nodejs 解释器环境
	-http://nodejs.cn/  下载对应平台的nodejs解释器
    -一路下一步安装
    -安装完成会有两个可执行问题
    	python    node 
        pip       npm
        
    -打开cmd
     node  进入到了node环境
     npm install 装模块
posted @ 2023-02-20 21:45  雪语  阅读(13)  评论(0编辑  收藏  举报