使用requirejs搭建前端项目

本文主要是讲述如何使用requirejs这个模块化管理工具来搭建前端项目结构,适合内网开发以及还在使用比较旧的技术栈(如jQuery)的前端同学。
github地址:https://github.com/duwenbin0316/Requirejs-demo.git,如果对你有帮助,请点个star,谢谢!
requirejs的使用我就一笔带过,主要是讲如何搭建项目结构。
项目基本目录结构如下:

项目目录结构

根目录下有index.html文件和scripts文件夹,我们把css文件和js文件放在一起处理,components目录下按照页面结构定义文件夹结构,例如footer文件夹就是用来处理页面footer的模块,文件夹中包括footer.js和footer.css文件,如果还需要拆分子组件,则继续嵌套即可。
这种目录结构的好处在于实现了模块功能和样式的高内聚,符合模块化开发的高内聚低耦合思想,项目也更容易维护。

在index.html中引入requirejs本身以及主js文件:

<script data-main="scripts/index" src="scripts/lib/require.js"/></script>

index.js定义了模块的名称和路径,以及模块所需的依赖,并调用了main模块的start方法:

require.config({
    baseUrl: "scripts/",
    map: {
        '*': {
            'css': 'lib/css.min'
        }
    },
    paths: {
        "jquery": "lib/jquery-2.1.4.min",
        "main": "main"
    },
    shim: {
        "main": {
            deps: ['jquery', 'css!./main.css']
        }
    }
})

require(['main'], function(main){
    main.start()
})

main.js为应用主模块,调用main.start()执行应用初始化,所有的dom创建都在模块内部处理,index.html中只有一个div#main的dom元素。main.js内容如下:

/**
 * 定义一个main模块
 */
define(function() {
    var main = function() {
        this.moduleName = 'main'
    }
    
    main.prototype = {
        start: function() {
            // 渲染页面布局
            this.renderLayout();

            // 调用header的start,渲染header内容
            require(['header'], function(header){
                header.start();
            })
        },

        renderLayout: function() {
            var left = $("<div>").addClass('sider left').prop('id', 'sider');

            var right = $("<div>").addClass('right');
            var header = $("<div>").prop('id', 'header');
            var content = $("<div>").prop('id', 'content');
            var footer = $("<div>").prop('id', 'footer');
            right.append(header, content, footer);

            $("#main").append(left, right);
        }
    }

    return new main();
});

同时在main.js中调用了header模块的start方法。

项目结构按照该思路一层一层构建,简单明了,当然也可以根据个人习惯提取出一些通用的组件,本文就不再赘述。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前端知识体系http://www.cnblogs.com/sb19871023/p/3894452.html 前端...
    秋风喵阅读 12,648评论 7 163
  • 春天的夜不热不冷 清新的气息令人神怡 春天的夜不闹不静 悄悄萌动着多少生命 嫩绿的小草钻出了土层 摆脱一个黑暗的梦...
    无语_2cd1阅读 248评论 0 0
  • 久到记不得蛋糕胚是什么味道的蛋糕,简单,凌乱。 照片记录:
    YI是可以的以阅读 184评论 0 0
  • 孤单的人都有颗孤独的心。 初冬的夜,昏黄的路灯拉长了人影。听着过路的汽笛声,别人的谈笑声,广场舞的音乐声。欢笑声,...
    清晨微雨_阅读 273评论 6 2
  • 初冬已过,天气越来越冷了。火车站台旁边的长椅上坐着一个穿着厚重棉祆的老妇人。她两眼发愣,死死的盯着从她眼前呼啸而过...
    凯里的珍珠阅读 403评论 0 8