Vue.component用法

当我们有一个共有功能时,在每个JS中都进行方法、属性的定义,代码就会十分冗余。此时我们可以使用vue.component。
将共有功能作为一个组件,在不同的html页面中直接传参调用即可。

例:

组件JS

(function(){
    
	var template = '<div style="display: inline-block">\n' +
        '<i class="iconfont iconlujing1" @click="relevanceData()" style="color: #00a0ee;cursor: pointer"></i>\n' +
        '<el-dialog\n' +
        'class="yyzwb el-dialog__header el-dialog__title"\n' +
        'title="关联指标"\n' +
        ':visible.sync="dialogVisible"\n' +
        ' width="30%">\n' +
        '<div v-if="dataList.length == 0">暂无数据</div>\n' +
        '<div v-for="(data,index) in dataList">\n' +
        '<div :style="{\'padding-top\': index==0 ? \'4px\' : \'24px\'}">\n' +
        '<div style="position: relative">\n' +
        '<div style="float:left; display:inline-block;height: 13px;width: 13px;border-radius: 50%;background: #349afb;position: absolute;top: 5px"></div>\n' +
        '<span style="font-weight: bolder;padding-left: 20px">{{data.gcd}}</span>\n' +
        '</div>\n' +
        '<div style="padding-bottom: 24px;">{{data.pfyd}}</div>\n' +
        '<div v-if="index != dataList.length -1" style="height: 0px;border: 1px solid #eeeeee;"></div>\n' +
        '</div>\n' +
        '</div>\n' +
        '<span class="dialog-footer"></span>\n' +
        '</el-dialog>\n' +
        ' </div>';

	// 'relevance':组件名称,页面通过该名称使用组件
	Vue.component('relevance', {
	    //template:使用组件时拼接的页面代码
		template: template,
        //props:页面传入的参数
		props: {
		    //页面传入参数名称,注:页面大小写使用‘-’分割 module-name
            moduleName:{
            	type:String,
                required:true
			}
		},

        //data
		data:function(){
			return {
                dialogVisible:false,		//是否显示弹框
				dataList:[]					//存放返回数据
			}
		},
        
        //方法
		methods: {
			//初始化加载
			init:function () {
				this.getRelevanceData();
            },

			//根据模块名称获取关联指标
            getRelevanceData:function () {
                var _this = this;
                $.ajax({
                    xhrFields: {
                        withCredentials: true
                    },
                    type: "POST",
                    async: false,
                    url: httpurl + 'templateManage/getRelevanceData',
                    data: {
						DM:this.moduleName
					},
                    dataType: "json",
                    success: function (data) {
                        if ("success" == data.result) {
                            _this.dataList = data.list
                       		console.log( _this.list);
                        }

                    }
                })
            },

			//显示弹框
            relevanceData:function () {
				this.dialogVisible = true
            }
		},

		mounted(){
			this.init();
		}

	})
})();

在页面引入该JS
在这里插入图片描述
在这里插入图片描述

注:

1.注意参数写法
在这里插入图片描述
2.组件需为立即调用函数

(function(){})()

查看JS立即执行

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值