RequireJS入门(二)

        上一篇是把整个jQuery库作为一个模块。这篇来写一个自己的模块:选择器。

        为演示方便这里仅实现常用的三种选择器id,className,attribute。RequireJS使用define来定义模块。

        目录结构如下:

        新建了一个子目录js,把main.js和selctor.js放入其中,require.js仍然和index.html在同一级目录。

index.html

<!doctype html>
<html>
	<head>
		<title>requirejs入门(二)</title>
		<meta charset="utf-8">
		<style type="text/css">
			.wrapper {
				width: 200px;
				height: 200px;
				background: gray;
			}
		</style>
 	</head>
 	<body>
		<div class="wrapper"></div>
		<script data-main="js/main" src="require.js"></script>
 	</body>
</html>

        这次把script标签放到了div的后面,因为要用选择器去获取页面dom元素,而这要等到dom ready后。

        因为把main.js放到js目录中,这里data-main的值须改为“js/main”。

selector.js

define(function() {
 
    function query(selector,context) {
        var s = selector,
            doc = document,
            regId = /^#[\w\-]+/,
            regCls = /^([\w\-]+)?\.([\w\-]+)/,
            regTag = /^([\w\*]+)$/,
            regNodeAttr = /^([\w\-]+)?\[([\w]+)(=(\w+))?\]/;
         
        var context = 
                context == undefined ?
                document :
                typeof context == 'string' ?
                doc.getElementById(context.substr(1,context.length)) :
                context;
                 
        if(regId.test(s)) {
            return doc.getElementById(s.substr(1,s.length));
        }
        // 略...
    }
    return query;
});

        define的参数为一个匿名函数,该匿名函数执行后返回query,query为函数类型。query就是选择器的实现函数。

main.js

require.config({
	baseUrl: 'js'
});

require(['selector'], function(query) {
	var els = query('.wrapper');
	console.log(els)
});

        require.config方法执行配置了baseUrl为“js”,baseUrl指的模块文件的根目录,可以是绝对路径或相对路径。这里用的是相对路径。相对路径指引入require.js的页面为参考点,这里是index.html。

运行结果:

网络请求如下:


        main.js和selector.js都请求下来了。

        selector.js下载后使用query获取页面class为“.wrapper”的元素,控制台输出了该元素。如下:

 

总结:

1.使用baseUrl来配置模块根目录,baseUrl可以是绝对路径也可以是相对路径。

2.使用define定义一个函数类型模块,RequireJS的模块可以是JS对象,函数或其它任何类型(CommonJS/SeaJS则只能是JS对象)。

 

文章来源:http://www.cnblogs.com/snandy/archive/2012/05/23/2513712.html

内容概要:本文详细介绍了使用COMSOL进行三相电力变压器温度场与流体场耦合计算的具体步骤和技术要点。首先讨论了变压器温升问题的重要性和现有仿真与实测数据之间的偏差,接着阐述了电磁-热-流三场耦合建模的难点及其解决方法。文中提供了关键的材料属性设置代码,如变压器油的密度和粘度随温度变化的关系表达式,并强调了网格划分、求解器配置以及后处理阶段需要注意的技术细节。此外,还分享了一些实用的经验和技巧,例如采用分离式步进求解策略、优化网格划分方式等,确保模型能够顺利收敛并获得精确的结果。最后,作者推荐了几种常用的湍流模型,并给出了具体的参数设置建议。 适用人群:从事电力系统设计、变压器制造及相关领域的程师和技术人员,特别是那些希望深入了解COMSOL软件在复杂多物理场耦合计算方面应用的人群。 使用场景及目标:适用于需要对变压器内部温度分布和油流情况进行精确模拟的研究或程项目。主要目的是提高仿真精度,使仿真结果更加贴近实际情况,从而指导产品设计和优化运行参数。 其他说明:文中不仅包含了详细的理论解释和技术指导,还提供了一些实际案例供读者参考。对于初学者来说,可以从简单的单相变压器开始练习,逐步掌握复杂的三相变压器建模技能。同时,作者提醒读者要注意单位的一致性和材料属性的准确性,这是避免许多常见错误的关键所在。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值