[JavaScript]自执行函数

最近在接触mui的时候,遇到了一段代码:

  1 (function($, doc) {
  2                 $.init({
  3                     statusBarBackground: ‘#f7f7f7‘
  4                 });
  5                 $.plusReady(function() {
  6                     plus.screen.lockOrientation("portrait-primary");
  7                     var settings = app.getSettings();
  8                     var state = app.getState();
  9                     var mainPage = $.preload({
 10                         "id": ‘main‘,
 11                         "url": ‘tab-webview-main.html‘
 12                     });
 13                     var main_loaded_flag = false;
 14                     mainPage.addEventListener("loaded",function () {
 15                         main_loaded_flag = true;
 16                     });
 17                     var toMain = function() {
 18                         //使用定时器的原因:
 19                         //可能执行太快,main页面loaded事件尚未触发就执行自定义事件,此时必然会失败
 20                         var id = setInterval(function () {
 21                             if(main_loaded_flag){
 22                                 clearInterval(id);
 23                                 $.fire(mainPage, ‘show‘, null);
 24                                 mainPage.show("pop-in");
 25                             }
 26                         },20);
 27                     };
 28
 29                     // close splash
 30                     setTimeout(function() {
 31                         //关闭 splash
 32                         plus.navigator.closeSplashscreen();
 33                     }, 600);
 34                     var loginButton = doc.getElementById(‘login‘);
 35                     var accountBox = doc.getElementById(‘account‘);
 36                     var passwordBox = doc.getElementById(‘password‘);
 37                     var autoLoginButton = doc.getElementById("autoLogin");
 38                     var regButton = doc.getElementById(‘reg‘);
 39                     var forgetButton = doc.getElementById(‘forgetPassword‘);
 40                     loginButton.addEventListener(‘tap‘, function(event) {
 41                         var username = $(‘#account‘).val();
 42                         var password = $(‘#password‘).val();
 43
 44                           // LeanCloud - 登录
 45                           // https://leancloud.cn/docs/leanstorage_guide-js.html#用户名和密码登录
 46                           AV.User.logIn(username, password).then(function (loginedUser) {
 47                                 toMain();
 48                           }, function (error) {
 49                                 // 导入AlertDialog类
 50                             var AlertDialog = plus.android.importClass("android.app.AlertDialog");
 51                                 // 创建提示框构造对象,构造函数需要提供程序全局环境对象,通过plus.android.runtimeMainActivity()方法获取
 52                             var dlg = new AlertDialog.Builder(plus.android.runtimeMainActivity());
 53                             // 设置提示框标题
 54                             dlg.setTitle("登陆失败");
 55                             // 设置提示框内容
 56                             dlg.setMessage("用户名或密码不正确!"+JSON.stringify(error));
 57                             // 设置提示框按钮
 58                             dlg.setPositiveButton("OK",null);
 59                             // 显示提示框
 60                             dlg.show();
 61                           });
 62                     });
 63                     $.enterfocus(‘#login-form input‘, function() {
 64                         $.trigger(loginButton, ‘tap‘);
 65                     });
 66                     autoLoginButton.classList[settings.autoLogin ? ‘add‘ : ‘remove‘](‘mui-active‘)
 67                     autoLoginButton.addEventListener(‘toggle‘, function(event) {
 68                         setTimeout(function() {
 69                             var isActive = event.detail.isActive;
 70                             settings.autoLogin = isActive;
 71                             app.setSettings(settings);
 72                         }, 50);
 73                     }, false);
 74                     regButton.addEventListener(‘tap‘, function(event) {
 75                         $.openWindow({
 76                             url: ‘reg.html‘,
 77                             id: ‘reg‘,
 78                             preload: true,
 79                             show: {
 80                                 aniShow: ‘pop-in‘
 81                             },
 82                             styles: {
 83                                 popGesture: ‘hide‘
 84                             },
 85                             waiting: {
 86                                 autoShow: false
 87                             }
 88                         });
 89                     }, false);
 90                     forgetButton.addEventListener(‘tap‘, function(event) {
 91                         $.openWindow({
 92                             url: ‘forget_password.html‘,
 93                             id: ‘forget_password‘,
 94                             preload: true,
 95                             show: {
 96                                 aniShow: ‘pop-in‘
 97                             },
 98                             styles: {
 99                                 popGesture: ‘hide‘
100                             },
101                             waiting: {
102                                 autoShow: false
103                             }
104                         });
105                     }, false);
106                     //
107                     window.addEventListener(‘resize‘, function() {
108                         oauthArea.style.display = document.body.clientHeight > 400 ? ‘block‘ : ‘none‘;
109                     }, false);
110                     //
111                     var backButtonPress = 0;
112                     $.back = function(event) {
113                         backButtonPress++;
114                         if (backButtonPress > 1) {
115                             plus.runtime.quit();
116                         } else {
117                             plus.nativeUI.toast(‘再按一次退出应用‘);
118                         }
119                         setTimeout(function() {
120                             backButtonPress = 0;
121                         }, 1000);
122                         return false;
123                     };
124                 });
125             }(mui, document));

mui

这就不懂了,为什么一个function函数要放在一个括号里面,括号里面还有一个括号(mui,document),看起来像是参数一样。还以为这是Native.js里面的内容,然后去官方文档中翻看了一下Njs的内容,并不是啊,然后去百度。

自执行函数

自执行函数(function(jquery){}(jquery));
* 相当于下面的代码:

var fun = function(jquery){};
fun(jquery);

* 立即执行匿名函数fun(jquery);主要是为了避免jquery与其他类库或变量有冲突。

百度中有好多jquery字样出现,但是并没有明确说跟jquery有关系,我也是不太清楚。

mui的demo中(function($, doc) {}(mui, document));据说可以让函数在文档加载完毕之后再执行,相当于

$(document).ready(function (){
    //函数体
});
时间: 2024-12-29 23:20:39

[JavaScript]自执行函数的相关文章

javascript立即执行函数

javascript和其他编程语言相比比较随意,所以javascript代码中充满各种奇葩的写法,有时雾里看花;当然,能理解各型各色的写法也是对javascript语言特性更进一步的深入理解.  ( function(){…} )()  和  ( function (){…} () )  是两种javascript立即执行函数的常见写法; 最初我以为是一个括号包裹匿名函数,再在后面加个括号调用函数,最后达到函数定义后立即执行的目的; 后来发现加括号的原因并非如此.要理解立即执行函数,需要先理解一

javascript立即执行函数 (function(){})()

看到一段代码: (function(){ var outer = $('#subject'); outer.find('li').on('mouseover', mouseover); })() ( function(){…} )()和( function (){…} () )是两种javascript立即执行函数的常见写法,且这个函数必须是函数表达式,不能是函数声明. 这样写的作用: javascript中没用私有作用域的概念,如果在多人开发的项目上,你在全局或局部作用域中声明了一些变量,可能

javascript立即执行函数表达式(IIFE)

常用的两种写法: (function(){ /* code */ }()); (推荐写法) (function(){ /* code */ })(); Q:为什么这样写,函数就嗯那个立即执行? A:因为在javascript里,括号内部不能包含语句,当解析器对代码进行解释的时候,先碰到了(),然后碰到function关键字就会自动将()里面的代码识别为函数表达式而不是函数声明. eg:如下代码就会报错. function(){ /* code */ }(); // SyntaxError: Un

Javascript 自动执行函数(立即调用函数)

开头:各种原因总结一下javascript中的自动执行函数(立即调用函数)的一些方法,正文如下 在Javascript中,任何function在执行的时候都会创建一个执行上下文,因为function声明变量和function有可能只在该function内部,这个上下文,在调用function的时候,提供一些简单的方式来创建自由变量或私有子function. eg: // 由于该function里返回了另外一个function,其中这个function可以访问自由变量i // 所有说,这个内部的f

Javascript自执行函数 (Immediately-Invoked Function Expression)

1. Javascript编译器在遇到function这个关键字时,默认认为它是function声明,而不是表达式. 2. 在已声明的function后面加括号,即可调用它.比如, function foo(){console.log('hello javascript.')} foo(); 3. 括号里面允许javascript表达式,(function(){console.log('hello javascript')}), 这样这个匿名函数就是一个表达式,而不是function的声明.根据

javascript自执行函数常见写法

代码: var obj = (function(a,b){ a.prop = b return a }(this,'hello')) 测试: console.log(obj.prop) 输出: hello [Finished in 0.4s] 原文地址:http://blog.51cto.com/12173069/2293788

javascript中的立即执行函数(function(){…})()

javascript中的立即执行函数(function(){…})() 深入理解javascript中的立即执行函数,立即执行函数也叫立即调用函数,通常它的写法是用(function(){…})()包住业务代码,使用jquery时比较常见. ( function(){…} )()和( function (){…} () )是两种javascript立即执行函数的常见写法,最初我以为是一个括号包裹匿名函数,再在后面加个括号调用函数,最后达到函数定义后立即执行的目的,后来发现加括号的原因并非如此.要

深入理解javascript中的立即执行函数(function(){…})()

这篇文章主要介绍了深入理解javascript中的立即执行函数,立即执行函数也叫立即调用函数,通常它的写法是用(function(){-})()包住业务代码,使用jquery时比较常见,需要的朋友可以参考下http://www.jb51.net/article/50967.htm javascript和其他编程语言相比比较随意,所以javascript代码中充满各种奇葩的写法,有时雾里看花,当然,能理解各型各色的写法也是对javascript语言特性更进一步的深入理解. ( function()

【转】深入理解javascript中的立即执行函数(function(){…})()

javascript和其他编程语言相比比较随意,所以javascript代码中充满各种奇葩的写法,有时雾里看花,当然,能理解各型各色的写法也是对javascript语言特性更进一步的深入理解. ( function(){…} )()和( function (){…} () )是两种javascript立即执行函数的常见写法,最初我以为是一个括号包裹匿名函数,再在后面加个括号调用函数,最后达到函数定义后立即执行的目的,后来发现加括号的原因并非如此.要理解立即执行函数,需要先理解一些函数的基本概念.