热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Requirejs高级应用(三):同步加载

在requirejs中,我们可以通过获取函数返回值的方式进行同步调用,如下:define([require],function(require){通过同步调用的方式

在requirejs中,我们可以通过获取函数返回值的方式进行同步调用,如下:

define(['require'], function(require) {
    // 通过同步调用的方式获取angular引用
    var angular = require('angular');
})

1. 同步加载要求

在requirejs中,执行同步加载必须满足两点要求:
1. 必须在定义模块时使用,亦即define函数中,看完第二个条件,你会明白这是必然的;
2. 引用的资源必须是之前异步加载过的(不必在同一个模块),换句话说,同步载入的模块是不会发网络请求的,只会调取之前缓存的模块;

如果没有满足上面两个条件,那么它一定会报错,如下:

require.js:143 Uncaught Error: 
Module name "require/require" has not been loaded yet for context: _. 
Use require([])(…)makeError
@ require.js:168localRequire 
@ require.js:1433requirejs 
@ require.js:1794(anonymous function) 
@ VM3806:1

满足了上面那么两个苛刻的条件,那同步加载还能引用于什么场景呢?

2. 应用场景1

已经明确知道模块的先后顺序,确认此模块已经被加载过,例如系统通用模块,在载入完成后,之后的模块就可以进行同步的引用,或者在Vue等前端技术框架中,在应用模块同步加载vue模块。

3. 应用场景2

引用的资源列表太长,懒得回调函数中写一一对应的相关参数,如下:

// 假定这里引用的资源有数十个,回调函数的参数必定非常多
define(['jquery'], function() {
    return function(el) {
        // 这就是传说中的同步调用
        var $ = require('jquery');
        $(el).html('Hello, World!');
    }
})

4. 引用场景3

可以减少命名或者命名空间冲突,例如prototype与jquery的冲突问题,如下:

define(['jquery', 'prototype'], function() {
    var export = {};
    export.jquery = function(el) {
        // 这就是传说中的同步调用
        var $ = require('jquery');
        $(el).html('Hello, World!');
    }

    export.proto = function(el) {
        // 这就是传说中的同步调用
        var $ = require('prototype');
        $(el).html('Hello, World!');
    }
    return export;
})

5. 引用场景4

处女座专用,代码显得更整洁漂亮了,硬是把回调函数写出了同步的感觉,有没有?

6. 结论

Requirejs的同步加载是鸡肋,跟你想象中的AJAX同步加载完全不一样,不一样!


推荐阅读
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • 本文讨论了如何根据特定条件动态显示或隐藏文件上传控件中的默认文本(如“未选择文件”)。通过结合CSS和JavaScript,可以实现更灵活的用户界面。 ... [详细]
  • 本文详细介绍了如何解决Uploadify插件在Internet Explorer(IE)9和10版本中遇到的点击失效及JQuery运行时错误问题。通过修改相关JavaScript代码,确保上传功能在不同浏览器环境中的一致性和稳定性。 ... [详细]
  • 导航栏样式练习:项目实例解析
    本文详细介绍了如何创建一个具有动态效果的导航栏,包括HTML、CSS和JavaScript代码的实现,并附有详细的说明和效果图。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 在使用 MUI 框架进行应用开发时,开发者常常会遇到 mui.init() 和 mui.plusReady() 这两个方法。本文将详细解释它们的区别及其在不同开发环境下的应用。 ... [详细]
  • Startup 类配置服务和应用的请求管道。Startup类ASP.NETCore应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:可选择性地包括 ... [详细]
  • 本文将深入探讨如何在不依赖第三方库的情况下,使用 React 处理表单输入和验证。我们将介绍一种高效且灵活的方法,涵盖表单提交、输入验证及错误处理等关键功能。 ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
author-avatar
痴情被撕碎的阳光
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有