国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

從hello world看JavaScript隱藏的黑魔法

cnio / 3210人閱讀

摘要:如果類型轉換你還不是很了解,可以先讀下這篇來理解一下從看隱式強制轉換機制。函數可對通過編碼的字符串進行解碼。而作者封裝的也是基于這兩者來實現輸出黑魔法字符串的。同時通過,返回了一個匿名函數形成了閉包。為了達到裝逼的效果。

寫在最前

事情的起因是這段看起來不像代碼的代碼:

有興趣的同學可以自己先嘗試下!

([]+[][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+(![]+[])[!+[]+!![]]+([]+{})[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+(!![]+[])[+[]]+([][[]]+[])[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]])())[+[]]+([][[]]+[])[!+[]+!![]+!![]]+(![]+[])[!+[]+!![]]+(![]+[])[!+[]+!![]]+([]+{})[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+[][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+([][[]]+[])[+[]]+([][[]]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(![]+[])[!+[]+!![]+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+([]+[][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+(![]+[])[!+[]+!![]]+([]+{})[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+(!![]+[])[+[]]+([][[]]+[])[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]])())[!+[]+!![]+!![]]+([][[]]+[])[!+[]+!![]+!![]])()([][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(![]+[])[!+[]+!![]+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+([]+[][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+(![]+[])[!+[]+!![]]+([]+{})[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+(!![]+[])[+[]]+([][[]]+[])[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]])())[!+[]+!![]+!![]]+([][[]]+[])[!+[]+!![]+!![]])()(([]+{})[+[]])[+[]]+(!+[]+!![]+!![]+!![]+!![]+!![]+!![]+[])+(!+[]+!![]+!![]+!![]+!![]+!![]+!![]+[]))+([]+{})[+!![]]+(!![]+[])[+!![]]+(![]+[])[!+[]+!![]]+([][[]]+[])[!+[]+!![]]+[][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+([][[]]+[])[+[]]+([][[]]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(![]+[])[!+[]+!![]+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+([]+[][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+(![]+[])[!+[]+!![]]+([]+{})[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+(!![]+[])[+[]]+([][[]]+[])[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]])())[!+[]+!![]+!![]]+([][[]]+[])[!+[]+!![]+!![]])()([][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(![]+[])[!+[]+!![]+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+([]+[][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+(![]+[])[!+[]+!![]]+([]+{})[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+(!![]+[])[+[]]+([][[]]+[])[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]])())[!+[]+!![]+!![]]+([][[]]+[])[!+[]+!![]+!![]])()(([]+{})[+[]])[+[]]+(!+[]+!![]+[])+(+!![]+[]))

作者對著這段代碼足足看了一下午,我只想說這不是什么深奧的黑魔法。一點點看下來你就知道其中的原理了。最后會有一段作者自己封裝的代碼叫nb.js(源碼在這里),它實現了輸入數字字母后自動生成這種玄學代碼片段。就像這樣:

歡迎關注我的博客,不定期更新中——

JavaScript小眾系列開始更新啦

——何時完結不確定,寫多少看我會多少!這是已經更新的地址:

小眾系列之按位非運算符:JavaScript中奇特的~運算符

小眾系列之終極類型轉換:從hello world看JavaScript隱藏的黑魔法制

小眾系列之隱式類型轉換:[從[] == ![]看隱式強制轉換機制](https://github.com/Aaaaaaaty/...

小眾系列之事件循環:從HTML5與PromiseA+規范來看事件循環

這個系列旨在對一些人們不常用遇到的知識點,以及可能常用到但不曾深入了解的部分做一個重新梳理,雖然可能有些部分看起來沒有什么用,因為平時開發真的用不到!但個人認為糟粕也好精華也罷里面全部蘊藏著JS一些偏本質的東西或者說底層規范,如果能適當避開舒適區來看這些小細節,也許對自己也會有些幫助~文章更新在我的博客,歡迎不定期關注。

轉換思路 基礎思路:通過關鍵字來獲取字母

什么意思?比如:f??吹絝你會想到哪個關鍵字?同時這個關鍵字是要在類型轉換的機制下能夠被打印出來的。如果類型轉換你還不是很了解,可以先讀下這篇來理解一下:[從[] == ![]看隱式強制轉換機制](https://github.com/Aaaaaaaty/...。我相信很多同學可以想到是false這個關鍵字。那么我們的思路就有了也就是要讓代碼實現"false"[0]這件事,這個認識統一之后我相信下面的代碼一定不難理解了:

[[[] == []] + []][+![]][+![]]
//過程理解為
[] == [] => false
[[] == []] => [false]
[[[] == []] + []] => ["false"], [+![]] => 0
[[[] == []] + []][+![]] => "false"
[[[] == []] + []][+![]][+![]] => "false"[0] => "f"

其中大體形式可以理解為:"false"[0] => "f"

是不是瞬間覺得也不過如此?

可通過關鍵字獲取的字符

當你知道可以用上面的方式來獲取自己需要的字母之后,接下來要做的是思考一下你能從關鍵字中獲取哪些字母呢,作者總結了以下你可以通過關鍵字獲得的字母:

([][[]]+[]) => "undefined"
+[1+[[][0]+[]][0][3]+400][0]+[] => "Infinity"
[[[] == []] + []][+![]] => "false"
[[[] != []] + []][+![]] => "true"
([]+{}) => "[object Object]"

感興趣的同學自己打印下就明白為什么了。

接下來要說的是剩下的字母怎么辦?當然了你仍然可以通過試圖尋找關鍵字的方式來獲取字母。但是如果標點我也想要呢?或者說26個字母我都想要怎么辦?
具體點來說對于“hello world!”這段字符串來看,至少“w”,"!"的獲取方法通過關鍵字的形式我們是無從下手的。

unescape
unescape() 函數可對通過 escape() 編碼的字符串進行解碼。但是已經廢棄了

是的現在已經不建議如此使用了,但是瀏覽器下基本還是支持這個函數的。通過這個函數我們可以通過ascll碼來直接得到我們需要的字符:

unescape("%77") => "w"

如此看來,除了我們可以快速得得到一些關鍵字字母外,用這個方法我們便可以實現任意字母的組合。而作者封裝的nb.js也是基于這兩者來實現輸出黑魔法字符串的。

那么現在的問題是如果通過字符串來執行unescape("%77")這段代碼?

來看下hello world那段代碼是如何實現的:


在這里也不繞彎子了,作者打印了很多次之后才發現是如此調用的:

[]["sort"]["constructor"]("return unescape")

因為JS調用方法不光是“.”調用,通過[]也是可以調用的。同時通過return unescape,返回了一個匿名函數形成了閉包。故調用的時候采用如下方式:

[]["sort"]["constructor"]("return unescape")()("%77") => "w"

至于為什么這段代碼寫出來如此長是因為上面的每一個字母都是一點點拼出來的,也行好上面通過關鍵字的方式可以得到這些字母=。=不然的話——

封裝nb.js

所以經過上面的分析你會發現,除了字符串長度感人之外,這種通過拼接字符串可以返回函數并且執行的方式還真是蠻炫酷的。為了達到裝逼的效果。作者決定封裝一個支持字母和數字的函數,當你傳入普通的字符串之后,會返回帶有黑魔法氣息的冗長字符串,盡情拿去裝x吧,不客氣~

封裝過程 維護基礎對象與ascll表對象
var baseAlibrary = {
    "a": "[[[] == []][0]+[]][0][1]",
    "b": null,
    "c": "[[][[[][0] + []][0][4]+[[][0] + []][0][5]+[[][0] + []][0][1]+[[][0] + []][0][2]]+[]][0][3]",
    "d": "([][[]]+[])[+!![]+!![]]",
    "e": "([][[]]+[])[+!![]+!![]+!![]]",
    "f": "([][[]]+[])[+!![]+!![]+!![]+!![]]",
    "g": null,
    ...
    "0": "(+![])",
    "1": "(+!![])",
    "2": "(+!![]+!![])",
    ...
    ",": null,
    "!": null,
    }
    var ascll = { //ascll表可自行配置, 新添加后需要在上面對象中配置相同key,只是value為null
        "A": "41",
        "B": "42",
        ...
    }

將簡單的字母轉換方式直接存儲下來,如果需要的字符無法從基礎對象獲取,就記為null,并在ascll表中寫入相關轉碼方式。

封裝unesacpe
var result = ""
    var unescapeStr = "[][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+([][[]]+[])[+[]]+([][[]]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(![]+[])[!+[]+!![]+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+([]+[][(![]+[])[!+[]+!![]+!![]]+([]+{})[+!![]]+(!![]+[])[+!![]]+(!![]+[])[+[]]][([]+{})[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]]+(![]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+[]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(!![]+[])[+[]]+([]+{})[+!![]]+(!![]+[])[+!![]]]((!![]+[])[+!![]]+([][[]]+[])[!+[]+!![]+!![]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!![]]+([][[]]+[])[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]+!![]+!![]]+(![]+[])[!+[]+!![]]+([]+{})[+!![]]+([]+{})[!+[]+!![]+!![]+!![]+!![]]+(+{}+[])[+!![]]+(!![]+[])[+[]]+([][[]]+[])[!+[]+!![]+!![]+!![]+!![]]+([]+{})[+!![]]+([][[]]+[])[+!![]])())[!+[]+!![]+!![]]+([][[]]+[])[!+[]+!![]+!![]])"
    //將[]["sort"]["constructor"]("return unescape")的黑魔法形式存儲起來之后直接調用
    function changeAscll(ascllItem) {
        var ascllResult = ""
        var middleValue = ""
        ascll[ascllItem].split("").forEach(function(item) {
            if(isNaN(item)) { //ascll中遇到字母則需要再次進行unescape轉碼
                var str = ""
                ascll[item].split("").forEach(function(data) {
                    str += "+[" + baseAlibrary[data] + "]"
                })
                middleValue += "+" + unescapeStr + "()("+ baseAlibrary["%"]+"+" +  str.slice(1) + ")"
            } else {
                middleValue += "+[" + baseAlibrary[item] + "]"
            }    
        })
        ascllResult += "+" + unescapeStr + "()("+ baseAlibrary["%"]+"+" +  middleValue.slice(1) + ")"
        return ascllResult
    }
    function getUnEscape(str) {

    }
    strArr.forEach(function(item) {
        Object.keys(baseAlibrary).forEach(function(obj, i) {
            if(item.toLocaleLowerCase() === obj) {
                if(!baseAlibrary[item]) {
                    Object.keys(ascll).forEach(function(ascllItem) {
                        if(obj === ascllItem) {
                            var cbValue = changeAscll(ascllItem).slice(1)
                            result += "+" + cbValue
                        }
                    })
                } else {
                    result += "+" + baseAlibrary[obj]
                }
            }
        })
    })
    console.log(result.slice(1))
效果

也就是一開始大家看到的:

作者將函數綁定在了this上,通過this.reallyNb()即可得到你想要的~

PS:代碼請部署在服務器中再打開頁面,否則個別字母通過location方法會取不到,主要就是t,p。不過這個問題之后作者會將其以ascll表的方式存儲,就沒有環境限制了。只是作者嫌棄那樣做打印的字符串太長了~

最后

不定時更新中——
有問題歡迎在issues下交流。

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/90612.html

相關文章

  • 手摸手教你用 js 寫一個 js 解釋器

    摘要:手摸手教你用寫一個解釋器用來編譯看起來是個高大上的東西,實際原理其實很簡單,無非就是利用對象屬性可以用字符串表示這個特性來實現的黑魔法罷了。 手摸手教你用 js 寫一個 js 解釋器 用 js 來 編譯 js 看起來是個高大上的東西,實際原理其實很簡單,無非就是利用 js 對象屬性可以用字符串表示 這個特性來實現的黑魔法罷了。之所以看起來那么 深奧, 大概是由于網上現有的教程,都是動不...

    hss01248 評論0 收藏0
  • __proto__ 屬性與 ES6 classes 的繼承

    摘要:即是由此我們可以輕松偽造一個實例對象可是這是對對象的屬性的修改,和有什么關系靜態方法的繼承少年,可別忘了函數本身也是個對象喲在上面的代碼中,我們使無關對象的指向構造函數的,于是使被判定為的實例。 關于 __proto__ 屬性,MDN 上的解釋是這樣的[1]: The __proto__ property of Object.prototype is an accessor prope...

    newsning 評論0 收藏0
  • CSS 行內對齊的黑魔法

    摘要:魔法完整代碼如下今日瞎選篇以上代碼運行效果和之前一摸一樣這里就不一一截圖費大家流量啦良心前端。。。。對這個屬性不熟悉的朋友可以去看的文檔幾種語法如下我們用的這個長度單位實際應用較少,卻是行內元素垂直對齊的黑魔法。 showImg(https://segmentfault.com/img/bVbhrMS?w=2936&h=1152); 本文和以前的文章類似,orange 盡量帶給大家分享...

    enda 評論0 收藏0
  • STIMULUS(二) —— Hello, Stimulus

    摘要:每個項目都是從開始的,此項目也不例外。控制器為帶來生命力作為其核心,的目標是自動將元素連接到對象。檢查是否生效刷新頁面,你會看到任何改變都沒有。在中,處理事件的控制器方法叫做操作方法。這意味這我們擁有了標準的重構技術兵工廠。 學習 Stimulus 的最簡單方式就是構建一個簡單的控制器。這一章我們就來學習一個。 先決條件 要往下繼續,你需要運行一個 stimulus-starter ,...

    bigdevil_s 評論0 收藏0
  • 【轉】如何前端工程師到前端架構師

    摘要:之前人家寫過的彈出層,富文本編輯器,語法高亮插件你一套也不能少,這樣你才能接觸到之前碰不到的原生與知識點。通過引入雙向綁定與分層架構,完全脫離進行前端開發。 原文:http://www.cnblogs.com/rubylouvre/p/3658441.html 作者:司徒正美 偶的《javascript框架設計》終于出版 歷時兩年多,我的書終于付梓出版了。應各方面的要求,寫軟文一篇...

    ShowerSun 評論0 收藏0

發表評論

0條評論

cnio

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<