zoukankan      html  css  js  c++  java
  • Backbone seajs

    <!doctype html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <script src="seajs/sea.js"></script>
        <style>
            span{display: block;}
            #container ul li{list-style-type: none;float: left;padding: 10px; margin-right: 10px;margin-bottom: 10px;}
            #container ul li img{display: block;width: 100px;height: 150px;}
            #container ul li p{white-space: nowrap;overflow: hidden; width: 100px;text-overflow: ellipsis;}
        </style>
    </head>
    <body>
        <div id="container">
            <ul></ul>
        </div>
    
        <!-- template -->
        <script type="text/html" id="book-view">
            <span class="books">
                <img src="<%= image %>" alt="<%= title %>">
                <p><a href="<%= alt %>"><%= title %></a></p>
            </span>
        </script>
        <script>
            seajs.config({
                base: '../example-3',
                alias: {
                    'jquery': 'lib/jquery-latest.js',
                    'underscore': 'lib/underscore.js',
                    'backbone': 'lib/backbone.js',
                    'DemoModel': 'js/DemoModel',
                    'DemoView': 'js/DemoView',
                    'DemoCollection': 'js/DemoCollection',
                    'DemoApp': 'js/DemoApp'
                }
            });
    
            seajs.use('DemoApp', function (DemoApp) {
                new DemoApp();
            });
        </script>
    </body>
    </html>
    define('DemoModel', ['jquery', 'underscore', 'backbone'], function (require, exports, module) {
        'use strict';
    
        var DemoModel = Backbone.Model.extend({
            defaults: function () {
                return {
                    id: '',
                    alt: '',
                    url: '',
                    title: '',
                    image: ''
                }
            }
        });
    
        module.exports = DemoModel;
    });
    define('DemoCollection', ['jquery', 'underscore', 'backbone', 'DemoModel'], function (require, exports, module) {
        'use strict';
        var DemoModel = require('DemoModel');
    
        var DemoCollection = Backbone.Collection.extend({
            model: DemoModel,
            url: 'https://api.douban.com/v2/book/search?q=javascript',
            parse: function (response) {
                return response.books;
            },
            sync: function (method, model, options) {
                var params = _.extend({
                    type: 'GET',
                    dataType: 'jsonp',
                    url: this.url,
                    processData: false
                }, options);
                return $.ajax(params);
            }
        });
    
        module.exports = DemoCollection;
    })
    define('DemoView', ['jquery', 'underscore', 'backbone'], function (require, exports, module) {
        'use strict';
    
        var DemoView = Backbone.View.extend({
            tagName: 'li',
            template: _.template($('#book-view').html()),
            render: function () {
                this.$el.html(this.template(this.model.toJSON()));
                return this;
            }
        });
    
        module.exports = DemoView;
    });
    define('DemoApp', ['jquery', 'underscore', 'backbone', 'DemoView', 'DemoCollection'], function (require, exports, module) {
        'use strict';
        var DemoCollection = require('DemoCollection'),
            DemoView = require('DemoView');
    
        var demoCollection = new DemoCollection();
    
        var DemoApp = Backbone.View.extend({
            el: 'body',
            events: {
    
            },
            initialize: function () {
                var that = this;
                this.listenTo(demoCollection, 'reset', this.render);
                demoCollection.fetch({
                    success: function (e) {
                        console.log('data');
                        that.render();
                    },
                    error: function (e) {
                        console.log('Something went wrong!');
                    }
                });
            },
            render: function () {
                demoCollection.each(this.addOne, this);
            },
            addOne: function (item) {
                var view = new DemoView({
                    model: item
                });
    
                $('#container ul').append(view.render().el);
            }
        });
    
        module.exports = DemoApp;
    });
  • 相关阅读:
    MySql 插入(insert)性能测试 zt 武胜
    mysql日期 武胜
    Some Useful Extension Methods On IList<T> zt 武胜
    SQL语句 武胜
    MySql bulk load zt 武胜
    C# 结构体初始化 武胜
    备忘 武胜
    C# 批量插入Mysql zt 武胜
    Use C# to get JSON Data from the Web and Map it to .NET Class => Made Easy! 转 武胜
    开发例子 转http://www.google.com.hk/search?newwindow=1&safe=strict&client=firefoxa&hs=Gzw&rls=org.mozilla%3AzhCN%3Aofficial&q=%E5%8D%83%E5%8F%91&oq=%E5% 武胜
  • 原文地址:https://www.cnblogs.com/wangwenfei/p/seajsbackbone.html
Copyright © 2011-2022 走看看