[JavaScript]自執行函數

来源:http://www.cnblogs.com/lxmwb/archive/2017/05/24/6900139.html
-Advertisement-
Play Games

最近在接觸mui的時候,遇到了一段代碼: 1 (function($, doc) { 2 $.init({ 3 statusBarBackground: '#f7f7f7' 4 }); 5 $.plusReady(function() { 6 plus.screen.lockOrientation( ...


最近在接觸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 (){
    //函數體
});

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 《大型分散式網站架構設計與實踐》主要介紹了大型分散式網站架構所涉及的一些技術細節,包括SOA架構的實現、互聯網安全架構、構建分散式網站所依賴的基礎設施、系統穩定性保障和海量數據分析等內容;深入地講述了大型分散式網站架構設計的核心原理,並通過一些架構設計的典型案例,幫助讀者瞭解大型分散式網站設計的一些 ...
  • 解釋器模式(interpreter), 最後一個模式了 最近比較苦b, 前同事內推某公司直接被拒, 理由學歷的問題, 現在立個flag, 1年之後進阿裡巴巴, 聽說阿裡巴巴沒有這個要求, 夢想還是要有的, 萬一實現了呢 解釋器模式(interpreter)定義 定義: 給定一個語言, 定義它的文法的 ...
  • 開閉原則是面向對象設計的一個重要原則,其定義如下: 開閉原則(Open-Closed Principle, OCP):一個軟體實體應當對擴展開放,對修改關閉。即軟體實體應儘量在不修改原有代碼的情況下進行擴展。 在軟體的生命周期內,因為變化、升級和維護等原因需要對軟體原有代碼進行修改時,可能會給舊代碼 ...
  • 實際參數在函數中我們可以使用 arguments 對象獲得 (註:形參可通過 arguments.callee 獲得),雖然 arguments 對象與數組形似,但仍不是真正意義上的數組。 我們可以通過數組的 slice 方法將 arguments 對象轉換成真正的數組。 方法一:通過Array.p ...
  • 常用正則表達式合集 驗證數字:^[0-9]+$驗證n位的數字:^\d{n}$驗證至少n位數字:^\d{n,}$驗證m-n位的數字:^\d{m,n}$驗證零和非零開頭的數字:^((0|[1-9])[0-9]*)$驗證有兩位小數的正實數:^(0|[1-9][0-9]*)(\.[0-9]{2})$驗證有1 ...
  • 1.jquery介紹:想必大家都用過jquery吧,這個曾經也是現在依然最流行的web前端js庫,可是現在無論是國內還是國外他的使用率正在漸漸被其他的js庫所代替,隨著瀏覽器廠商對HTML5規範統一遵循以及ECMA6在瀏覽器端的實現,jquery的使用率將會越來越低 2.vue介紹:vue是一個興起 ...
  • 之前有在網上找ajax上傳圖片的資料,大部分的人寫得都是用jQuery,但是在這裡用JQuery就大才小用了,所以我就自己寫了,先上圖。 由上圖,首先點擊上面的選擇文件,在選擇圖片之後,將會自動上傳圖片到伺服器,並且返回圖片名字和圖片在伺服器的路徑,然後在頁面顯示文件名字和圖片。 源碼:http:/ ...
  • <node.js的特點> 採用了非同步式I/O與事件驅動的架構設計,架構為單線程模型。 <supervisor包的作用> node.js開發項目,當修改項目時,需要終止進程重啟Node.js之後才可以看到修改後的效果,為瞭解決這個問題,我們可以安裝supercisor這個包,其主要作用是監視代碼的變動 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...