解析angularjs数组的传参方式
本篇文章主要介绍了angularjs的数组传参方式的简单实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
初学 angularjs时,对 数组传参方式感到很好奇([‘a', ‘b', function(a,b){}]),它到底怎么实现的呢?后来由于工作很忙,对这个问题也就慢慢忘记了。
今天闲来无事,有想到了这个问题。最简单的方法就是查看他的源代码。无奈本人E文不好,不说看他的设计逻辑,仅看英文注释就够我头疼了。尝试闭门造车,最终竟然把车造出来了。
既然自己造的车,就要带上自己的名(取姓名拼音第一个字母),就叫他mqyJs把,下面是演示的调用方法:
var app2 = mqyJs.applicationCreate([{ name: '直接传入SCOPE' }, '$hello', '$world', function($scope, $hello, $world) { return $scope.name + ": " + $hello.name + $world.name; }]);
核心部分如下:
//框架开设 var mqyJs = { //服务注册 servicesList: {}, servicesRegister: function(name, value) { this.servicesList[name] = value; }, //应用创建 applicationList: [], applicationCreate: function(_opts, _args) { if (!_args) { _args = _opts; _opts = {} } _opts.scope = _opts.scope || { name: 'SCOPE没有设置' }; if (!(_args instanceof Array)) { _args = ['$scope', _args]; } if (typeof _args[_args.length - 1] != 'function') { throw new Error('参数中没有指定运行函数'); } _args.map((arg, index) => { if (typeof arg == 'string') { if (arg === '$scope') { _args[index] = _opts.scope; } else { if (!!arg && !(arg in this.servicesList)) { throw new Error('插件:' + arg + ' 还没有注册'); } _args[index] = this.servicesList[arg]; } } }); return this.applicationList[this.applicationList.push({ run: function(callback) { if (typeof callback != 'function') { callback = function(_opts) { return _opts; } } return callback(_args[_args.length - 1].apply(null, _args)); } }) - 1]; } }; //框架结束
通过 servicesRegister,可以注册 服务,比如 angularjs 的 $http;
//插件开始 mqyJs.servicesRegister('$hello', { name: '你好' }); mqyJs.servicesRegister('$world', { name: '世界' }); mqyJs.servicesRegister('$china', { name: '中国' }); //插件结束
最终,对所有注册的应用,自动执行
/** * 初始化完成后系统自动运行 * 比如网页中 放到 window.onload */ mqyJs.applicationList.map(function(app, index) { console.log('自动调用 -> APP #' + index + ' -> ' + app.run()); });
尝试跑一下代码,能自动识别参数类型,完美执行。
不传入 $scope 时,程序会自动创建一个 $scope。
//演示代码 开始 var app = mqyJs.applicationCreate(['$scope', '$hello', '$china', function($scope, $hello, $china) { return $scope.name + ": " + $hello.name + $china.name; }]); var app2 = mqyJs.applicationCreate([{ name: '直接传入SCOPE' }, '$hello', '$world', function($scope, $hello, $world) { return $scope.name + ": " + $hello.name + $world.name; }]); var app3 = mqyJs.applicationCreate([{ name: 'world也直接传入' }, '$hello', { name: '地球' }, function($scope, $hello, $world) { return $scope.name + ": " + $hello.name + $world.name; }]); var app4 = mqyJs.applicationCreate(function($scope) { return $scope.name; }); var opts = { scope: { name: '自定义SCOPE' } }; var app5 = mqyJs.applicationCreate(opts, function($scope) { return $scope.name; }); app4.run(function(result) { console.log('手动调用 -> RESULT -> ' + result); }); //演示代码 结束
为了方便测试,再把代码重新写一遍,直接复制下面的代码到 浏览器控制台即可测试
//框架开设 var mqyJs = { //服务注册 servicesList: {}, servicesRegister: function(name, value) { this.servicesList[name] = value; }, //应用创建 applicationList: [], applicationCreate: function(_opts, _args) { if (!_args) { _args = _opts; _opts = {} } _opts.scope = _opts.scope || { name: 'SCOPE没有设置' }; if (!(_args instanceof Array)) { _args = ['$scope', _args]; } if (typeof _args[_args.length - 1] != 'function') { throw new Error('参数中没有指定运行函数'); } _args.map((arg, index) => { if (typeof arg == 'string') { if (arg === '$scope') { _args[index] = _opts.scope; } else { if (!!arg && !(arg in this.servicesList)) { throw new Error('插件:' + arg + ' 还没有注册'); } _args[index] = this.servicesList[arg]; } } }); return this.applicationList[this.applicationList.push({ run: function(callback) { if (typeof callback != 'function') { callback = function(_opts) { return _opts; } } return callback(_args[_args.length - 1].apply(null, _args)); } }) - 1]; } }; //框架结束 //插件开始 mqyJs.servicesRegister('$hello', { name: '你好' }); mqyJs.servicesRegister('$world', { name: '世界' }); mqyJs.servicesRegister('$china', { name: '中国' }); var app = mqyJs.applicationCreate(['$scope', '$hello', '$china', function($scope, $hello, $china) { return $scope.name + ": " + $hello.name + $china.name; }]); var app2 = mqyJs.applicationCreate([{ name: '直接传入SCOPE' }, '$hello', '$world', function($scope, $hello, $world) { return $scope.name + ": " + $hello.name + $world.name; }]); var app3 = mqyJs.applicationCreate([{ name: 'world也直接传入' }, '$hello', { name: '地球' }, function($scope, $hello, $world) { return $scope.name + ": " + $hello.name + $world.name; }]); var app4 = mqyJs.applicationCreate(function($scope) { return $scope.name; }); var opts = { scope: { name: '自定义SCOPE' } }; var app5 = mqyJs.applicationCreate(opts, function($scope) { return $scope.name; }); app4.run(function(result) { console.log('手动调用 -> RESULT -> ' + result); }); //插件结束 mqyJs.applicationList.map(function(app, index) { console.log('自动调用 -> APP #' + index + ' -> ' + app.run()); });
以上是解析angularjs数组的传参方式的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

如何使用WebSocket和JavaScript实现在线语音识别系统引言:随着科技的不断发展,语音识别技术已经成为了人工智能领域的重要组成部分。而基于WebSocket和JavaScript实现的在线语音识别系统,具备了低延迟、实时性和跨平台的特点,成为了一种被广泛应用的解决方案。本文将介绍如何使用WebSocket和JavaScript来实现在线语音识别系

WebSocket与JavaScript:实现实时监控系统的关键技术引言:随着互联网技术的快速发展,实时监控系统在各个领域中得到了广泛的应用。而实现实时监控的关键技术之一就是WebSocket与JavaScript的结合使用。本文将介绍WebSocket与JavaScript在实时监控系统中的应用,并给出代码示例,详细解释其实现原理。一、WebSocket技

如何利用JavaScript和WebSocket实现实时在线点餐系统介绍:随着互联网的普及和技术的进步,越来越多的餐厅开始提供在线点餐服务。为了实现实时在线点餐系统,我们可以利用JavaScript和WebSocket技术。WebSocket是一种基于TCP协议的全双工通信协议,可以实现客户端与服务器的实时双向通信。在实时在线点餐系统中,当用户选择菜品并下单

如何使用WebSocket和JavaScript实现在线预约系统在当今数字化的时代,越来越多的业务和服务都需要提供在线预约功能。而实现一个高效、实时的在线预约系统是至关重要的。本文将介绍如何使用WebSocket和JavaScript来实现一个在线预约系统,并提供具体的代码示例。一、什么是WebSocketWebSocket是一种在单个TCP连接上进行全双工

JavaScript和WebSocket:打造高效的实时天气预报系统引言:如今,天气预报的准确性对于日常生活以及决策制定具有重要意义。随着技术的发展,我们可以通过实时获取天气数据来提供更准确可靠的天气预报。在本文中,我们将学习如何使用JavaScript和WebSocket技术,来构建一个高效的实时天气预报系统。本文将通过具体的代码示例来展示实现的过程。We

JavaScript教程:如何获取HTTP状态码,需要具体代码示例前言:在Web开发中,经常会涉及到与服务器进行数据交互的场景。在与服务器进行通信时,我们经常需要获取返回的HTTP状态码来判断操作是否成功,根据不同的状态码来进行相应的处理。本篇文章将教你如何使用JavaScript获取HTTP状态码,并提供一些实用的代码示例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用于在DOM树中插入一个新的节点。这个方法需要两个参数:要插入的新节点和参考节点(即新节点将要被插入的位置的节点)。

JavaScript是一种广泛应用于Web开发的编程语言,而WebSocket则是一种用于实时通信的网络协议。结合二者的强大功能,我们可以打造一个高效的实时图像处理系统。本文将介绍如何利用JavaScript和WebSocket来实现这个系统,并提供具体的代码示例。首先,我们需要明确实时图像处理系统的需求和目标。假设我们有一个摄像头设备,可以采集实时的图像数
