zoukankan      html  css  js  c++  java
  • vue-demo

    <!DOCTYPE html>
    <html lang="en">
    <head>
    <meta charset="utf-8">
    <script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
    <style>
    .container {
    500px;
    height: 500px;
    border: 1px solid skyblue;
    }
    li {
    list-style: none;
    100%;
    }
    .des {
    100%;
    height: 50px;
    background-color: grey;
    display: none;
    }
    .show {
    display: block;
    }
    /*淡入淡出效果*/
    .fade-enter-active, .fade-leave-active {
    transition: all .2s;
    }
    .fade-enter, .fade-leave-active {
    opacity: 0;
    height: 0px;
    }
    </style>
    </head>
    <body>
    <div id="app">
    <accord
    :list='msgs'
    >
    </accord>
    </div>
    </body>
    <script type='text/x-template' id='tpl1'>
    <div class="panel">
    <li>
    <p @click="toggle">{{title}}</p>
    <transition name="fade">
    <div class='des' :class='{show:active}' v-if="active">
    <slot>
    {{text}}
    </slot>
    </div>
    </transition>
    </li>
    </div>
    </script>
    <script type='text/x-template' id='tpl2'>
    <div class="container">
    <panel v-for="(item, index) in list"
    :title="item.title"
    :text="item.text"
    :active="activeIndex === index"
    @toggle="activeIndex = index"
    >
    <div style="border: 1px solid red">
    {{item.text}}
    </div>
    </panel>
    </div>
    </script>
    <script>
    var panelComponent = {
    template: '#tpl1',
    props: {
    title: String,
    text: String,
    active: {
    default: false,
    type: Boolean
    }
    },
    data: function () {
    return {}
    },
    methods: {
    toggle: function () {
    this.$emit('toggle')
    }
    }
    }
    var panelComponent = {
    template: '#tpl1',
    props: {
    title: String,
    text: String,
    active: {
    default: false,
    type: Boolean
    }
    },
    data: function () {
    return {}
    },
    methods: {
    toggle: function () {
    this.$emit('toggle')
    }
    }
    }
    var accordionComponent = {
    template: '#tpl2',
    components: {
    'panel': panelComponent
    },
    data: function () {
    return {
    activeIndex: 0
    }
    },
    props: {
    list: {
    type: Array,
    default: []
    }
    },
    methods: {}
    }
    var vm = new Vue({
    el: '#app',
    components: {
    'accord': accordionComponent
    },
    data: {
    msgs: [
    {title: '1111111', text: '111111111'},
    {title: '2222222', text: '222222222'},
    {title: '3333333', text: '333333333'}
    ]
    },
    methods: {}
    })
    </script>
    </html>

  • 相关阅读:
    实践出真知关于ios项目重命名的实践 (xcode 4.3.1) ,以及svn 导出项目命令
    解决error: linker command failed with exit code 1类似的错误
    关于对ios 目录路径的理解
    UITableView 隔行换色 选中背景色 取消选中颜色 返回后显示正常颜色
    NSLog的常用格式说明小释
    app打包总结 以及 提交app审核过程
    UIView圆角
    substringToIndex substringFromIndex
    ios 判断文字高度,适用于tableview的自定义高度
    [转]android解析XML总结
  • 原文地址:https://www.cnblogs.com/luxiaoxiao/p/6706474.html
Copyright © 2011-2022 走看看