vue框架 之 组件

一、介绍:

1) 组件:一个包含html、css、js独立的集合体,这样的集合体可以完成页面解构的代码复用

2) 分组分为根组件、全局组件与局部组件

  根组件:所有被new Vue()产生的组件,在项目开发阶段,一个项目只会出现一个根组件 ;

  全局组件:不用注册,就可以成为任何一个组件的子组件 ;

  局部组件:必须注册,才可以成为注册该局部组件的子组件 。

3) 每一个组件都有自身的html结构,css样式,js逻辑

  每一个组件其实都有自己的template,就是用来标识自己html结构的 ;

  template模板中有且只有一个根标签 ;

  根组件一般不提供template,就由挂载点的真实DOM提供html结构。

二、组件:

  1、根组件

    在Vue内增 template:·<div> </div>·

  2、局部组件

    1)创建局部组件

    2)在父组件中注册该局部组件

    3)在父组件中的template模板中渲染该局部组件

</head>
<body>
    <div id="app">
        <!--<mcc></mcc>-->
        <local-tag></local-tag>
        <local-tag></local-tag>
    </div>
</body>
<script src="js/vue.js"></script>

<script>

    // 渲染
    let localTag = {
        template: `
        <div class="box">
            <img src="img/666.jpg" alt="">
            <h3>title</h3>
            <p>text</p>
        </div>
        `
    };
    new Vue({
        el: ‘#app‘,
        components: {    // 注册
            // mcc: localTag,
            // localTag,
            ‘local-tag‘: localTag,
        }
    })
</script>    

  3、全局组件

    1)创建全局组件

    2)在父组件的template模板中直接渲染该全局组件

全局组件与数据隔离

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <title></title>
    <style>
        .box {
            box-shadow: 0 3px 5px 0 #666;
            width: 240px;
            height: 300px;
            text-align: center;
            padding: 20px 0;
            float: left;
            margin: 5px;
        }
        .box img {
            width: 200px;
        }
    </style>
</head>
<body>
    <div id="app">
        <global-tag></global-tag>
        <global-tag></global-tag>
        <global-tag></global-tag>
    </div>
</body>
<script src="js/vue.js"></script>
<script>
    // 1) 创建全局组件
    // 2) 在父组件的template模板中直接渲染该全局组件
    Vue.component(‘global-tag‘, {
        template: `
        <div class="box" @click="action">
            <img src="img/666.jpg" alt="">
            <h3>凤哥</h3>
            <p>马叉虫?{{ num }}</p>
        </div>
        `,
        data () {
            return {
                num: 0
            }
        },
        methods: {
            action() {
                this.num++;
            }
        }
    });

    // 数据局部化分析导入
    // a = function () {
    //     return {num: 10}
    // };
    // b1 = a();
    // b2 = a();
    // b3 = a();

    new Vue({
        el: ‘#app‘,
    })
</script>
</html>

三、组件交互

1、父传子

// 数据交互 - 父传子 - 通过绑定属性的方式
// 1) 父组件提供数据
// 2) 在父组件模板中,为子组件标签设置自定义属性,绑定的值由父组件提供
// 3) 在子组件实例中,通过props实例成员获得自定义属性

<style>
    .info {
        text-align: center;
        width: 200px;
        padding: 3px;
        box-shadow: 0 3px 5px 0 pink;
        float: left;
        margin: 5px;
    }
    .info img {
        width: 200px;
    }
</style>
<div id="app">
    <!-- 2) 在父组件模板中,为子组件标签设置自定义属性,绑定的值由父组件提供 -->
    <info v-for="info in infos" :key="info.image" :myinfo="info"></info>
</div>
<script src="js/vue.js"></script>
<script>
    // 伪代码:模拟数据从后台请求
    /*
    let infos = ‘‘;
    document.onload = function () {
        $.ajax({
            url: ‘/images/‘,
            type: ‘get‘,
            success (response) {
                infos = response.data
            }
        })
    };
     */

    let infos = [
        {
            image: ‘img/001.png‘,
            title: ‘小猫‘
        },
        {
            image: ‘img/002.png‘,
            title: ‘蛋糕‘
        },
        {
            image: ‘img/003.png‘,
            title: ‘蓝糕‘
        },
        {
            image: ‘img/004.png‘,
            title: ‘恶犬‘
        },
    ];

    let info = {
        template: `
        <div class="info">
            <img :src="myinfo.image" >
            <p><b>{{ myinfo.title }}</b></p>
        </div>
        `,
        // 3) 在子组件实例中,通过props实例成员获得自定义属性
        props: [‘myinfo‘]
    };

    new Vue({
        el: ‘#app‘,
        components: {
            info,
        },
        data: {
            infos,  // 1) 父组件提供数据
        }
    })
</script>

2、子传父

// 组件交互-子传父
// 1) 数据由子组件提供
// 2) 子组件内部通过触发系统事件,发送一个自定义事件,将数据携带出来
// 3) 父组件位子组件标签的自定义属性通过方法实现,就可以通过参数拿到子组件传递处理的参数

<style>
    .close:hover {
        cursor: pointer;
        color: red;
    }
</style>
<div id="app">
    <p>
        <input type="text" v-model="userMsg">
        <button @click="sendMsg">留言</button>
    </p>
    <ul>
        <!-- 2) 子组件内部通过触发系统事件,发送一个自定义事件,将数据携带出来 -->
        <msg-li @remove_msg="removeAction" v-for="(msg, i) in msgs" :msg="msg" :index="i" :key="msg"></msg-li>
    </ul>
</div>
<script src="js/vue.js"></script>
<script>
    let msgLi = {
        template: `
        <li>
            <span class="close" @click="deleteMsg(index)">x </span>
            <span>第{{ index + 1 }}条:</span>
            <span>{{ msg }}</span>
        </li>
        `,
        props: [‘msg‘, ‘index‘],
        methods: {
            // 系统的click事件
            deleteMsg(i) {
                // 1) 数据由子组件提供
                // $emit(‘自定义事件名‘, 参数们)
                this.$emit(‘remove_msg‘, i);
            }
        }
    };
    new Vue({
        el: ‘#app‘,
        data: {
            msgs: [],
            userMsg: ‘‘
        },
        methods: {
            sendMsg() {
                if (this.userMsg) {
                    this.msgs.push(this.userMsg);
                    this.userMsg = "";
                }
            },
            // 3) 父组件位子组件标签的自定义属性通过方法实现,就可以通过参数拿到子组件传递处理的参数
            removeAction(i) {
                this.msgs.splice(i, 1)
            }
        },
        components: {
            msgLi
        }
    })
</script>

原文地址:https://www.cnblogs.com/xiaowangba9494/p/11645125.html

时间: 2024-11-21 05:47:46

vue框架 之 组件的相关文章

Vue框架——页面组件中使用小组件

小组件在components文件夹中,页面组件在views文件夹中 一.先写小组件的vue,比如text.vue(在template设置模板渲染,style设置样式) <template> <div class="text"> <p>tttt</p> </div> </template> <script> export default { name: "text" } </sc

基于vue项目的组件中导入mui框架初始化滑动等效果时需移除严格模式的问题

基于vue项目的组件中导入mui框架初始化滑动等效果时,控制台报错:Uncaught TypeError: 'caller', 'callee', and 'arguments' properties may not be accessed on strict mode functions or the arguments objects for calls to them 可使用 babel-plugin -transform-remove-strict-mode 移除严格模式 可先进行$ n

vue框架下的组件化的购物车实现

最近在学习vue,然后了解到这个框架的一个突出特点就是组件化,所以用这种形式实现了一个购物车,因为在实际项目中,数量加减可能不只在购物车里用到,所以把这个小的效果也提取出来了,在实现过程中形成了很多坑,这里记录一下,希望对大家能有所帮助. tip1: 这里会用到使用的组件库是vux,  需要先安装(npm insatall vux --save   npm install vux-loader --save-dev),然后具体怎么使用,如果不清楚请去看vux官网. 我把列表和底部的全选计数分别写

六.web框架-----------VUE语法使用组件(六)

一 .VUE语法使用组件 https://cn.vuejs.org/v2/guide/routing.html https://cn.vuejs.org/v2/guide/components.html https://www.jianshu.com/p/9dda283b7482 1.组件语法编写方式 <body> <div id="box"> <aaa></aaa> </div> <script> // exte

工作流,WEB框架,UI组件网络收集整理

工作流,WEB框架,UI组件网络收集整理 在博客园上逛了好多年,随手收录了一些工作流,WEB开发框架,UI组件,现在整理一下与大家分享. 由于个人能力与精力有限,望各位园友在评论中补充,我将全部整理到正文: ? 工作流篇 RoadFlow工作流(收费):                  http://www.cqroad.cn/WorkFlow 驰骋工作流引擎 ccflow                       https://www.oschina.net/p/ccflow YbSof

vue框架(一)

vue是什么? vue:一个构建用户界面的框架. 1在HTML元素显示数据 {{}} v-text v-html 2指令: 通过指令,来给DOM元素赋值或者其它操作:v-text v-html 根据表达式的真假值,动态地插入.移除元素:v-text v-html v-if\v-else 根据表达式的真假值,动态地显示.隐藏元素:v-show 根据数值渲染元素列表:v-for 绑定元素的属性,可以动态改变:v-bind 根据命令监听且执行事件:v-on v-model:数据双向绑定 它是把视图和数

Vue框架的使用。

使用VUE首先需要下载安装一些列的环境. 第一步: 安装Node.js 下载并安装:node-v8.9.0-x64.msi 第二步: 安装Vue脚手架: cmd以管理员身份执行 npm install vue-cli -g 或者安装淘宝版 cnpm install vue-cli -g vue -V  查看是否安装成功 第三步: 创建项目: vue init webpack myProject  (项目名字) 提示内容: 然后初始化: vue init webpack myProject 第四步

[转]VUE优秀UI组件库合集

原文链接 随着SPA.前后端分离的技术架构在业界越来越流行,前端的业务复杂度也越来越高,导致前端开发者需要管理的内容,承担的职责越来越多,这一切,使得业界对前端开发方案的思考多了很多,以react.vue等框架为代表推动的组件化开发模式越来越被开发者认可,这种模式极大的降低了我们开发与维护的成本.vue作为一款深受广大群众以及尤大崇拜者的喜欢,特此列出在github上开源的vue优秀UI组件库供大家参考,期待开发者们推出更多优秀的组件库. 本文分为两大部分介绍:PC端和移动端. 首先介绍PC端

在Vue框架中引入Element

文章会讲到如何在Vue框架中引入Element 那我们先来说一下Vue框架:Vue是渐进式,JavaScript框架.很多人不理解什么是渐进式,简单点讲就是易用.灵活.高效(没有太多限制) 这里介绍npm安装方式: 打开cmd,找到你Vue项目的路径 运行 npm i element-ui -S 然后在main.js里写入以下内容: import Vue from 'vue'; import ElementUI from 'element-ui'; import 'element-ui/lib/