Vue.js第三波,直接上代碼

Vue.js第三波,直接上代碼css

必需要寫代碼才能快速熟悉,學到 v-if 的時候就把我整蒙了,看教程還要問度娘,多方面尋找答案,才能真正瞭解框架性能。html

html部分 ↓ vue

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title>Vue</title>
        <link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/3.3.5/css/bootstrap.min.css" />
    </head>
    <body>
        <div class="container">
            <div class="col-md-8 col-md-offset-3">
                <h1>Vue demo</h1>
                <div id="app">
                    <div>{{message + 'Vue is awesome'}}</div>
                    <div>{{message.split('').reverse().join('')}}</div>
                    <input type="text" v-model="message"/>
                    <br />
                    <select v-model="selected"  multiple>
                        <option selected>a</option>
                        <option>b</option>
                        <option>c</option>
                    </select>
                    <br />
                    <span>Selected: {{ selected | json }}</span>
                    <br />
                    <table class="table table-striped text-right">
                        <tr class="info">
                            <td>序號</td>
                            <td>書名</td>
                            <td>做者</td>
                            <td>價格</td>
                            <td>操做</td>
                        </tr>
                        <tr class="success" v-for="book in books ">
                            <td>{{book.id}}</td>
                            <td>{{book.name}}</td>
                            <td>{{book.author}}</td>
                            <td>{{book.price}}</td>
                            <td><button class="btn btn-danger" @click="delBook(book)">刪除</button></td>
                        </tr>
                    </table>
                    <button class="btn btn-success" @click="doSomething">doSomething</button>
                    <div id="add-book">
                        <legend>添加書籍</legend>
                        <div class="form-group">
                            <label for="">書名</label>
                            <input type="text" class="form-control" v-model="book.name"/>
                        </div>
                        <div class="form-group">
                            <label for="">做者</label>
                            <input type="text" class="form-control" v-model="book.author"/>
                        </div>
                        <div class="form-group">
                            <label for="">價格</label>
                            <input type="text" class="form-control" v-model="book.price"/>
                        </div>
                        <button class="btn btn-primary btn-block" @click="addBook()">添加</button>
                        <br />
                        
                    </div>
                    <input type="text" v-model="newTodo" @keyup.enter="addTodo"/>
                    <ul>
                        <li v-for="todo in todos">
                            <span>{{ todo.text }}</span>
                            <button @click="removeTodo($index)">X</button>
                        </li>
                    </ul>
                    <div>
                        a = {{ a }}, b = {{ b }}
                    </div>
                    <input type="text" v-model="a"/>
                    <div>
                        {{ fullName }}
                    </div>
                    <div>
                        {{ allName }}
                    </div>
                    <div class="static" v-bind:class="{ 'class-a': isA, 'class-b': isB }">
                        對象語法,傳對象
                    </div>
                    <div v-bind:class="classObject">
                        對象語法,綁定數據裏的對象
                    </div>
                    <div v-bind:class="[classA,classB]">
                        數組語法,傳數組
                    </div>
                    <div v-bind:class="[classA, isA ? classB : '']">
                        數組語法,三元表達式
                    </div>
                    <div v-bind:class="[classA, { 'classB': isA, 'classC': isA }]">
                        當有多個條件class時,能夠在數組語法中使用對象語法
                    </div>
                    <div :style="{ color: activeColor, fontSize: fontSize + 'px' }">
                        綁定內聯樣式,對象語法
                    </div>
                    <div :style="styleObject">
                        綁定內聯樣式,對象語法直接綁定一個樣式對象
                    </div>
                    <div :style="[styleObjectA, styleObjectB]">
                        綁定內聯樣式,數組語法,多個樣式對象應用到一個元素上
                    </div>
                    {{#if ok}}
                    <h1>Hello</h1>
                    {{if}}
                    <h1 v-if="ok">Yes</h1>
                    <h1 v-else>No</h1>
                    
                    <template v-if="ok">
                      <h1 :style="[styleObjectB]">Title</h1>
                      <p :style="[styleObjectB]">Paragraph 1</p>
                      <p :style="[styleObjectB]">Paragraph 2</p>
                    </template>
                    
                    <h1 v-show="ok">Hello!</h1>
                    
                    <div v-if="Math.random() > 0.5">
                      Sorry
                    </div>
                    <div v-else>
                      Not sorry
                    </div>
                    <custom-component v-show="condition">警告組件</custom-component>
                    <p v-show="!condition" class="btn btn-primary btn-block">這可能也是一個警告組件</p>
                    <ul>
                      <li v-for="item in items" :style="styleObject">
                        {{ item.message }}
                      </li>
                    </ul>
                    <h1>v-for遍歷對象,用$index</h1>
                    <ul>
                      <li v-for="item in items">
                        {{ parentMessage }} - {{ $index }} - {{ item.message }}
                      </li>
                    </ul>
                    <div v-for="(index, item) in items">
                        {{ index }} {{ item.message }}
                    </div>
                    <div v-for="item of items">
                        {{ index }} {{ item.message}}
                    </div>
                    <ul>
                      <template v-for="item in items" track-by="id">
                        <li>
                            {{ item.message }}
                            <button class="btn btn-danger" @click="removeItem(item)">刪除</button>
                        </li>
                        <li class="divider"></li>
                      </template>
                    </ul>
                    <h1>v-for遍歷對象,除了$index,還能夠用$key</h1>
                    <ul>
                        <li v-for="value in uname">
                            {{ $key }} : {{ value }}
                        </li>
                    </ul>
                    <div>
                        <h1>值域v-for</h1>
                        <span v-for="n in 10" :style="styleObjectB">{{ n }}</span>
                    </div>
                    
                </div>
            </div>
        </div>
        <script src="http://cdn.jsdelivr.net/vue/1.0.26/vue.min.js"></script>
        <script src="js/app.js"></script>
    </body>
</html>json


js部分 ↓bootstrap

var vm = new Vue({
    el: '#app',
    data: {
        message: 'Hello vue.js',
        a: 1,
        isA: true,
        isB: false,
        classObject: {
            'class-a': false,
            'class-b': true
        },
        classA: 'class-a',
        classB: 'class-b',
        classC: 'class-c',
        firstName: 'Foo',
        lastName: 'Bar',
        book: {
            id: 0,
            author: '',
            name: '',
            price: ''
        },
        books: [{
            id: 1,
            author: '曹雪芹',
            name: '紅樓夢',
            price: 32.0
        },{
            id: 2,
            author: '施耐庵',
            name: '水滸傳',
            price: 30.0
        },{
            id: 3,
            author: '羅貫中',
            name: '三國演義',
            price: 24.0
        },{
            id: 4,
            author: '吳承恩',
            name: '西遊記',
            price: 20.0
        }],
        newTodo: '',
        todos: [{
            text: 'Add some todos'
        }],
        activeColor: 'red',
        fontSize: 30,
        styleObject: {
            color: 'blue',
            fontSize: '12px',
            listStyle: 'none'
        },
        styleObjectA: {
            background: '#f1f1f1'
        },
        styleObjectB: {
            textAlign: 'center',
            color: '#7eccf3',
            fontWeight: 'bold'
        },
        ok: true,
        items: [
            { id: 1, message: '列表渲染' },
            { id: 2, message: 'Foo' },
            { id: 3, message: 'Bar' }
        ],
        parentMessage: 'Parent',
        uname: {
            firstName: 'John',
            lastName: 'Doe',
            age: 30
        }
        
    },
    methods: {
        doSomething: function () {
            window.location.href= 'http://www.jinxiaowang.cn'
        },
        addBook: function () {
            this.book.id = this.books.length + 1;
            this.books.push(this.book);
            this.book = '';
        },
        delBook: function (book) {
            this.books.$remove(book);
        },
        addTodo: function () {
            var text = this.newTodo.trim();
            if(text){
                this.todos.push({text:text});
                this.newTodo = '';
            }
        },
        removeTodo: function (index) {
            this.todos.splice(index,1);
        },
        removeItem: function (item) {
            this.items.$remove(item)
        }
    },
    created: function () {
        console.log('a is: ' + this.message);
    },
    computed: {
        b: function () {
            var x = parseInt(this.a, 10) + 2;
            return x;
        },
        fullName: function () {
            return this.firstName + ' ' + this.lastName;
        },
        allName: {
            get: function () {
                return this.firstName + ' ' + this.lastName;
            },
            set: function (nameValue) {
                var names = nameValue.split(' ');
                this.firstName = names[0];
                this.lastName = names[names.length - 1]
            }
        }
    }
    
});數組

//vm.$watch('firstName', function (val) {
//    this.fullName = val + ' ' + this.lastName;
//});
    
//vm.$watch('lastName',function (val) {
//    this.fullName = val + ' ' + this.firstName;
//});app

//vm.items = vm.items.filter(function (item) {
//    return item.message.match(/Foo/)
//})
    
 框架

相關文章
相關標籤/搜索