Vue2 (一)组件定义

vue都火了好久了,一直想研究研究。今天终于写了第一个组件

js代码

//右边图片菜单
var imgMenuTemp=Vue.extend({
    data(){

    },
    methods:{
        //点击菜单子项 切换相应的界面展示。
        changeSpace:(event)=>{
            var el=event.target;
            if(AssertUtils.isNotEmpty(el.id)){

            }
        }
    },
    template:(()=>{
        let menuItems=[{name:'个人空间',id:'personSpace'},{name:'单位空间',id:'orgSpace'},{name:'集团空间',id:'jtSpace'}];let menus=[];
        //循环数组来构建菜单
        menuItems.forEach(function({id,name},index){
            let activeCss=index==0?"active":"";
            menus.push(`<div class="menuLi  ${activeCss}" ><div class="content" id="${id}">${name}</div></div>`);
        })
        let menuContent=menus.join("\n");
        return `<div class="spaceMenu" @click="changeSpace">${menuContent}</div>`
    })()
});

//vue 主函数
var vueObj=new Vue({
    el:"#mainPage",
    components:{
        'imgmenu': imgMenuTemp
    }
})

html代码:

   <div class="rightCell">
            <imgmenu></imgmenu>
            </div>

注意事项:

  • 定义的标签明不能用驼峰命名imgmenu。【刚开始我定义imgMenu则通过不了】
  • template直接用this.变量名,是获取不到data中数据。
 template:(()=>{
        let menuItems=[{name:'个人空间',id:'personSpace'},{name:'单位空间',id:'orgSpace'},{name:'集团空间',id:'jtSpace'}];let menus=[];
        //循环数组来构建菜单
        menuItems.forEach(function({id,name},index){
            let activeCss=index==0?"active":"";
            menus.push(`<div class="menuLi  ${activeCss}" ><div class="content" id="${id}">${name}</div></div>`);
        })
        let menuContent=menus.join("\n");
        return `<div class="spaceMenu" @click="changeSpace">${menuContent}</div>`
    })()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值