摘要:也可以補(bǔ)充好之前在這個(gè)最小物聯(lián)網(wǎng)系統(tǒng)缺失的那些東西,給那些正在開始試圖去解決編程問題的人。在線查看一步步搭建物聯(lián)網(wǎng)系統(tǒng)圖靈電子書版一步步搭建物聯(lián)網(wǎng)系統(tǒng)
某一天,正走在回學(xué)校的路上的我突然想到:“未來將會(huì)是一個(gè)科技的時(shí)代——雖然現(xiàn)在也是——只是在未來,科技將會(huì)無處不在。如果我們依舊對(duì)周圍這些無處不在的代碼一無所知的話,或許我們會(huì)成為黑客帝國之中被控制的普通人?!庇谑情_始想著,有一天人們會(huì)像學(xué)習(xí)一門語言一樣開始學(xué)習(xí)編程,直到又有一天我看到了學(xué)習(xí)編程如同學(xué)習(xí)一門語言的說法。這又恰好在我做完最小物聯(lián)網(wǎng)系統(tǒng)之后,算是一個(gè)有趣的時(shí)間點(diǎn),我開始想著像之前做最小物聯(lián)網(wǎng)系統(tǒng)的那些步驟一樣,寫一個(gè)簡單的入門。也可以補(bǔ)充好之前在這個(gè)最小物聯(lián)網(wǎng)系統(tǒng)缺失的那些東西,給那些正在開始試圖去解決編程問題的人。
讓我們先從身邊的語言下手,也就是現(xiàn)在無處不在的html+javascript+css。
無處不在的HTML之所以從html開始,是因?yàn)槲覀儾恍枰渲靡粋€(gè)復(fù)雜的開發(fā)環(huán)境,也許你還不知道開發(fā)環(huán)境是什么東西,不過這也沒關(guān)系,畢竟這些知識(shí)需要慢慢的接觸才能有所了解,尤其是對(duì)于普通的業(yè)余愛好者來說,當(dāng)然,對(duì)于專業(yè)選手言自然不是問題。HTML是Web的核心語言,也算是比較基礎(chǔ)的語言。
html的hello,worldHello,world是一個(gè)傳統(tǒng),所以在這里也遵循這個(gè)有趣的傳統(tǒng),我們所要做的事情其實(shí)很簡單,雖然也有一點(diǎn)點(diǎn)hack的感覺?!屛覀兿葋硇陆ㄒ粋€(gè)文并命名為"helloworld.html"。
(PS:大部分人應(yīng)該都是在windows環(huán)境下工作的,所以你需要新建一個(gè)文本,然后重命名,或者你需要一個(gè)編輯器,在這里我們推薦用sublime text。破解不破解,注冊(cè)不注冊(cè)都不會(huì)對(duì)你的使用有太多的影響。)
新建文件
輸入
hello,world
保存為->"helloworld.html",
雙擊打開這個(gè)文件。 正常情況下都應(yīng)該是用你的默認(rèn)瀏覽器打開。只要是一個(gè)正常工作的現(xiàn)代瀏覽器,都應(yīng)該可以看到上面顯示的是"Hello,world"。
這才是最短的hello,world程序,但是呢?在ruby中會(huì)是這樣子的
bash2.0.0-p353 :001 > p "hello,world" "hello,world" => "hello,world" 2.0.0-p353 :002 >
等等,如果你了解過html的話,會(huì)覺得這一點(diǎn)都不符合語法規(guī)則,但是他工作了,沒有什么比安裝完Nginx后看到It works!更讓人激動(dòng)了。
遺憾的是,它可能無法在所有的瀏覽器上工作,所以我們需要去調(diào)試其中的bug。
調(diào)試hello,world我們會(huì)發(fā)現(xiàn)我們的代碼在瀏覽器中變成了下面的代碼,如果你和我一樣用的是chrome,那么你可以右鍵瀏覽器中的空白區(qū)域,點(diǎn)擊審查元素,就會(huì)看到下面的代碼。
html hello,world
這個(gè)才是真正能在大部分瀏覽器上工作的代碼,所以復(fù)制它到編輯器里吧。
說說hello,world我很不喜歡其中的<*>*>,但是我也沒有找到別的方法來代替它們,所以這是一個(gè)設(shè)計(jì)得當(dāng)?shù)恼Z言。甚至大部分人都說這算不上是一門真正的語言,不過html的原義是
超文本標(biāo)記語言
所以我們可以發(fā)現(xiàn)其中的關(guān)鍵詞是標(biāo)記——markup,也就是說html是一個(gè)markup,head是一個(gè)markup,body也是一個(gè)markup。
然而,我們真正工作的代碼是在body里面,至于為什么是在這里面,這個(gè)問題就太復(fù)雜了。打個(gè)比方來說:
我們所使用的漢語是人類用智慧創(chuàng)造的,我們所正在學(xué)的這門語言同樣也是人類創(chuàng)造的。
我們?cè)谧约旱恼Z言里遵循著桌子是桌子,凳子是凳子的原則,很少有人會(huì)問為什么。
想用中文?所以我們也可以把計(jì)算機(jī)語言與現(xiàn)實(shí)世界里用于交流溝通的語言劃上一個(gè)等號(hào)。而我們所要學(xué)習(xí)的語言,并不是我們最熟悉的漢語語言,所以我們便覺得這些很復(fù)雜,但是如果我們?cè)囍脻h語替換掉上面的代碼的話
HTML<語言> <頭><結(jié)束頭> <身體>你好,世界<結(jié)束身體> <結(jié)束語言>
這看上去很奇怪,只是因?yàn)槭侵弊g過去的原因,也許你會(huì)覺得這樣會(huì)好理解一點(diǎn),但是輸入上可就一點(diǎn)兒也不方便,因?yàn)檫@鍵盤本身就不適合我們?nèi)ポ斎霛h字,同時(shí)也意味著可能你輸入的會(huì)有問題。
讓我們把上面的代碼代替掉原來的代碼然后保存,打開瀏覽器會(huì)看到下面的結(jié)果
HTML<語言> <頭><結(jié)束頭> <身體>你好,世界<結(jié)束身體> <結(jié)束語言>
更不幸的結(jié)果可能是
HTML<璇█> <澶?><緇撴潫澶?> <韜綋>浣犲ソ錛屼笘鐣?<緇撴潫韜綋> <緇撴潫璇█>
這是一個(gè)編碼問題,對(duì)中文支持不友好。
我們把上面的代碼改為和標(biāo)記語言一樣的結(jié)構(gòu)
HTML<語言> <頭>頭> <身體>你好,世界身體> <結(jié)束語言>
于是我們看到的結(jié)果便是
HTML<語言> <頭> <身體>你好,世界
被chrome瀏覽器解析成什么樣了?
html<語言> <頭> <身體>你好,世界
以
結(jié)尾的是注釋,寫給人看的代碼,不是給機(jī)器看的,所以機(jī)器不會(huì)去理解這些代碼。
但是當(dāng)我們把代碼改成
HTML你好世界
瀏覽器上面顯示的內(nèi)容就變成了
HTML你好世界
或許你會(huì)覺得很神奇,但是這一點(diǎn)兒也不神奇,雖然我們的中文語法也遵循著標(biāo)記語言的標(biāo)準(zhǔn),但是我們的瀏覽器不支持中文標(biāo)記。
結(jié)論:
瀏覽器對(duì)中文支持不友好。
瀏覽器對(duì)英文支持友好。
剛開始的時(shí)候不要對(duì)中文編程有太多的想法,這是很不現(xiàn)實(shí)的:
現(xiàn)有的系統(tǒng)都是基于英語語言環(huán)境構(gòu)建的,對(duì)中文支持不是很友好。
中文輸入的速度在某種程度上來說沒有英語快。
我們離開話題已經(jīng)很遠(yuǎn)了,但是這里說的都是針對(duì)于那些不滿于英語的人來說的,只有當(dāng)我們可以從頭構(gòu)建一個(gè)中文系統(tǒng)的時(shí)候才是可行的,而這些就要將cpu、軟件、硬件都包含在內(nèi),甚至我們還需要考慮重新設(shè)計(jì)cpu的結(jié)構(gòu),在某種程度上來說會(huì)有些不現(xiàn)實(shí)?;蛟S,需要一代又一代人的努力。忘記那些吧,師夷長之技以治夷。
其他html標(biāo)記添加一個(gè)標(biāo)題,
HTML標(biāo)題 hello,world
我們便可以在瀏覽器的最上方看到“標(biāo)題”二字,就像我們常用的淘寶網(wǎng),也包含了上面的東西,只是還包括了更多的東西,所以你也可以看懂那些我們可以看到的淘寶的標(biāo)題。
html標(biāo)題 hello,world大標(biāo)題
次標(biāo)題
...
- 列表1
- 列表2
更多的東西可以在一些書籍上看到,這邊所要說的只是一次簡單的語言入門,其他的東西都和這些類似。
美妙之處我們簡單地上手了一門不算是語言的語言,瀏覽器簡化了這其中的大部分過程,雖然沒有C和其他語言來得有專業(yè)感,但是我們?cè)囍ラ_始寫代碼了。我們可能在未來的某一篇中可能會(huì)看到類似的語言,諸如python,我們所要做的就是
bash$ python file.py =>hello,world
然后在終端上返回結(jié)果。只是因?yàn)樵谖铱磥韺W(xué)會(huì)html是有意義的,簡單的上手,然后再慢慢地深入,如果一開始我們就去理解指針,開始去理解類。我們甚至還知道程序是怎么編譯運(yùn)行的時(shí)候,在這個(gè)過程中又發(fā)生了什么。雖然現(xiàn)在我們也沒能理解這其中發(fā)生了什么,但是至少展示了
中文編程語言在當(dāng)前意義不大,不現(xiàn)實(shí),效率不高兼容性差
語言的語法是固定的。(ps:雖然我們也可以進(jìn)行擴(kuò)充,我們將會(huì)在后來支持上述的中文標(biāo)記。)
已經(jīng)開始寫代碼,而不是還在配置開發(fā)環(huán)境。
隨身的工具才是最好的,最常用的code也才是實(shí)在的。
更多我們還沒有試著去解決“某商店里的糖一顆5塊錢,小明買了3顆糖,小明一共花了多少錢”的問題。也就是說我們學(xué)會(huì)的是一個(gè)還不能解決實(shí)際問題的語言,于是我們還需要學(xué)點(diǎn)東西,比如javascript,css。我們可以將Javascript理解為解決問題的語言,html則是前端顯示,css是配置文件,這樣的話,我們會(huì)在那之后學(xué)會(huì)成為一個(gè)近乎專業(yè)的程序員。我們剛剛學(xué)習(xí)了一下怎么在前端顯示那些代碼的行為,于是我們還需要Javascript。
在線查看:一步步搭建物聯(lián)網(wǎng)系統(tǒng)
圖靈-電子書版一步步搭建物聯(lián)網(wǎng)系統(tǒng)
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/85475.html
摘要:也可以補(bǔ)充好之前在這個(gè)最小物聯(lián)網(wǎng)系統(tǒng)缺失的那些東西,給那些正在開始試圖去解決編程問題的人。在線查看一步步搭建物聯(lián)網(wǎng)系統(tǒng)圖靈電子書版一步步搭建物聯(lián)網(wǎng)系統(tǒng) 某一天,正走在回學(xué)校的路上的我突然想到:未來將會(huì)是一個(gè)科技的時(shí)代——雖然現(xiàn)在也是——只是在未來,科技將會(huì)無處不在。如果我們依舊對(duì)周圍這些無處不在的代碼一無所知的話,或許我們會(huì)成為黑客帝國之中被控制的普通人。于是開始想著,有一天人們會(huì)像學(xué)...
摘要:也可以補(bǔ)充好之前在這個(gè)最小物聯(lián)網(wǎng)系統(tǒng)缺失的那些東西,給那些正在開始試圖去解決編程問題的人。在線查看一步步搭建物聯(lián)網(wǎng)系統(tǒng)圖靈電子書版一步步搭建物聯(lián)網(wǎng)系統(tǒng) 某一天,正走在回學(xué)校的路上的我突然想到:未來將會(huì)是一個(gè)科技的時(shí)代——雖然現(xiàn)在也是——只是在未來,科技將會(huì)無處不在。如果我們依舊對(duì)周圍這些無處不在的代碼一無所知的話,或許我們會(huì)成為黑客帝國之中被控制的普通人。于是開始想著,有一天人們會(huì)像學(xué)...
摘要:與類選擇器最常一起出現(xiàn)的是選擇器,不過這個(gè)適用于比較高級(jí)的場合,諸如用控制的時(shí)候就需要用到選擇器。在線查看一步步搭建物聯(lián)網(wǎng)系統(tǒng)圖靈電子書版一步步搭建物聯(lián)網(wǎng)系統(tǒng) 無處不在的CSS 或許你覺得CSS一點(diǎn)兒也不重要,而事實(shí)上,如果說HTML是建筑的框架,CSS就是房子的裝修。那么Javascript呢,我聽到的最有趣的說法是小三——還是先讓我們回到代碼上來吧。 CSS 下面就是我們之前...
摘要:與類選擇器最常一起出現(xiàn)的是選擇器,不過這個(gè)適用于比較高級(jí)的場合,諸如用控制的時(shí)候就需要用到選擇器。在線查看一步步搭建物聯(lián)網(wǎng)系統(tǒng)圖靈電子書版一步步搭建物聯(lián)網(wǎng)系統(tǒng) 無處不在的CSS 或許你覺得CSS一點(diǎn)兒也不重要,而事實(shí)上,如果說HTML是建筑的框架,CSS就是房子的裝修。那么Javascript呢,我聽到的最有趣的說法是小三——還是先讓我們回到代碼上來吧。 CSS 下面就是我們之前...
閱讀 2978·2021-11-25 09:43
閱讀 3600·2021-11-24 11:13
閱讀 3373·2021-10-14 09:42
閱讀 2578·2021-09-23 11:53
閱讀 3622·2021-09-22 15:57
閱讀 3233·2021-09-02 09:54
閱讀 3510·2019-08-30 13:47
閱讀 1650·2019-08-29 16:55