avalon学习笔记(五)

五,搭建一个工程环境

到此,基础的理论都搞得差不多了,是时候做个实际的例子

换个教程,根据《avalon学习教程》系列--《1、引入avalon》建立一个新项目。

我用的vs2013community版

首先open->web site,指向一个空目录

新建两个folder,一个modules,一个reference。

Modules里存放网站的一个一个模块,reference里面放上我们要用到的第三方库,比如avalon,还有常用的requirejs,jquery等等

按照例子里说的,用到了avalon(我打算用modern版本),requirejs(及其插件domready,css,text),jquery

因为用到了require和domready,avalon里自带的就可以删掉了。

因为用的是modern版,需要仿照shim版改一下

从AMD加载器开始,都注掉,然后把shim里的end开始的代码拷过来。

然后把文件名里的modern去掉,还叫avalon

然后是作为入口的两个文件

Index.html

<!DOCTYPE html>
<html>
<head>
    <title>avalon练习</title>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width">
    <script src="Reference/require/require.js" data-main="main.js"></script>
    <style>
        .ms-controller {
            visibility: hidden;
        }
    </style>

</head>
<body ms-controller="root">
    <div>{{header | html}}</div>
    <div ms-include-src="page"></div>
    <div>{{footer}}</div>
</body>
</html>

有几个东西还是值得注意下

首先是引到了requirejs,data-main是requirejs的属性,指明了最外层的js

然后,把body分成了三个部分,分别绑定了header和footer,header还是按html的格式来解析。

中间用了一个叫page的模板

Style应该是用来保证画面不闪出绑定前的内容,这个入门教程里有提。

然后是main.js

require.config({//第一块,配置
    baseUrl: '',
    paths: {
        jquery: 'Reference/jquery/jquery-2.1.3',
        avalon: "Reference/avalon/avalon",//必须修改源码,禁用自带加载器,或直接删提AMD加载器模块
        text: 'Reference/require/text',
        domReady: 'Reference/require/domReady',
        css: 'Reference/require/css'
    },
    priority: ['text', 'css'],
    shim: {
        jquery: {
            exports: "jQuery"
        },
        avalon: {
            exports: "avalon"
        }
    }
});

require(['avalon', "domReady!"], function () {//第二块,添加根VM(处理共用部分)
    avalon.log("加载avalon完毕,开始构建根VM与加载其他模块")
    avalon.templateCache.empty = " "
    avalon.define("root",function(vm){
        vm.header= "这是根模块,用于放置其他模块都共用的东西,比如<b>用户名</b>什么的",
        vm.footer= "页脚消息",
        vm.page= "empty",
        vm.page2="empty"
    })
    avalon.scan(document.body)

    require(['./modules/testModule/test'], function () {//第三块,加载其他模块
        avalon.log("加载其他完毕")
    });

});

主要都是requirejs的格式,这个需要看requirejs的文档,大概就是给每个js设定一个名字,然后直接在js里引用名字就可以了

第一块,是requirejs的配置

第二块,就是root的viewmodel定义

第三块,是加载别的模块了,我这里起名字叫testModule

每个模块应该至少包括一个html和一个js,所以新建两个文件,一个test.html,一个test.js,放到testModule文件夹下

test.html

<div ms-controller="testVM">
    <input ms-duplex="value" />{{value}}
</div>

test.js

define(["avalon", "text!./test.html"], function (avalon, test) {

    avalon.templateCache.test = test
    avalon.define("testVM",function(vm){
        vm.value= "test text"
    })
    avalon.vmodels.root.page = "test"
})

avalon.templateCache.test = test和avalon.vmodels.root.page = "test"这两句话很关键。

avalon.templateCache.test = test是说把test.html加入到templateCache里,并定义个名字叫test

avalon.vmodels.root.page = "test"是说把一开始在main.js里定义的root的page属性改成刚才定义的test。

这样,test.html里的内容就可以在index的第二个div里显示出来了。

Ok,到此为止,用avalon结合requirejs就生成了一个简单的网站开发工程环境

可喜可贺,可喜可贺

时间: 2024-10-13 12:45:20

avalon学习笔记(五)的相关文章

Caliburn.Micro学习笔记(五)----协同IResult

Caliburn.Micro学习笔记(五)----协同IResult 今天说一下协同IResult 看一下IResult接口 /// <summary> /// Allows custom code to execute after the return of a action. /// </summary> public interface IResult { /// <summary> /// Executes the result using the specif

angular学习笔记(五)-阶乘计算实例(1)

<!DOCTYPE html> <html ng-app> <head> <title>2.3.2计算阶乘实例1</title> <meta charset="utf-8"> <script src="../angular.js"></script> <script src="script.js"></script> </

NLTK学习笔记(五):分类和标注词汇

[TOC] 词性标注器 之后的很多工作都需要标注完的词汇.nltk自带英文标注器pos_tag import nltk text = nltk.word_tokenize("And now for something compleyely difference") print(text) print(nltk.pos_tag(text)) 标注语料库 表示已经标注的标识符:nltk.tag.str2tuple('word/类型') text = "The/AT grand/J

Linux System Programming 学习笔记(五) 进程管理

1. 进程是unix系统中两个最重要的基础抽象之一(另一个是文件) A process is a running program A thread is the unit of activity inside of a process the virtualization of memory is associated with the process, the threads all share the same memory address space 2. pid The idle pro

java之jvm学习笔记五(实践写自己的类装载器)

java之jvm学习笔记五(实践写自己的类装载器) 课程源码:http://download.csdn.net/detail/yfqnihao/4866501 前面第三和第四节我们一直在强调一句话,类装载器和安全管理器是可以被动态扩展的,或者说,他们是可以由用户自己定制的,今天我们就是动手试试,怎么做这部分的实践,当然,在阅读本篇之前,至少要阅读过笔记三. 下面我们先来动态扩展一个类装载器,当然这只是一个比较小的demo,旨在让大家有个比较形象的概念. 第一步,首先定义自己的类装载器,从Clas

WEB前端学习笔记 五

接web前端学习笔记第四篇,此篇为web学习笔记 五,在此感谢您的采集和转发,但请注明文章出自网知博学. 2.0.3  html标签的属性格式 现在我们知道了两个双标签分别是,标题标签:<h1> - <h6>.和段落标签:<p></p>还知道了一个换行的单标签:<br />,现在我们给<p></p>标签添加一个属性,来改变段落是右对齐,还是左对齐,还是居中. 如上图,<p>标签中的 align(中文就是排列的意

小猪的数据结构学习笔记(五)

小猪的数据结构学习笔记(五) 线性表之--循环链表                           --转载请注明出处:coder-pig 循环链表知识点归纳: 相关代码实现: ①判断是否为空表: ②单循环链表的存储结构 其实和单链表的结构是一样的! /*定义循环链表的存储结构*/ typedef struct Cir_List { int data; struct Cir_List *next; }Lnode; ③初始化循环单链表 代码如下: //1.循环链表的初始化 //表示一个元素,如

python之list(学习笔记五)

python之list(学习笔记五) Python内置的一种数据类型是列表:list.list是一种有序的集合,可以随时添加和删除其中的元素. 比如,列出公司里同事的名字,就可以用一个list表示: >>> worker = ['wtf','laotan','xiaoxian'] >>> worker ['wtf', 'laotan', 'xiaoxian'] 变量 worker 就是一个list.用 len() 函数可以获得list元素的个数: >>>

Boost Thread学习笔记五

多线程编程中还有一个重要的概念:Thread Local Store(TLS,线程局部存储),在boost中,TLS也被称作TSS,Thread Specific Storage.boost::thread库为我们提供了一个接口简单的TLS的面向对象的封装,以下是tss类的接口定义: class tss{public:    tss(boost::function1<void, void*>* pcleanup);    void* get() const;    void set(void*

Swift学习笔记五:循环和条件语句

一.循环语句 1. for循环 1) for -in 循环,对于数据范围,序列,集合等中的每一个元素,都执行一次 for a in 0...5{}    //循环迭代,从a=0到a=5,执行{}里的代码 注意:a只循环中存在,也就是出了{}a就不存在了 或者遍历数组 let a = [1,2,3] for b in a{} //循环迭代,从b=1到b=3 如果你不需要序列中的每一个值,可以使用_来忽略它,仅仅只是使用循环体本身: for _ in 0...5{}    //循环执行{}里的代码,