整合營銷服務商

          電腦端+手機端+微信端=數據同步管理

          免費咨詢熱線:

          想提高JavaScript編碼能力?記住這些秘訣

          想提高JavaScript編碼能力?記住這些秘訣

          文共5024字,預計學習時長15分鐘

          來源:Pexels


          今天,小芯給大家分享一些提高JavaScript編碼能力的應用方法,學習并運用到實踐中,你也可以成為編碼熟練工喲~

          編輯器


          目前,編輯器種類繁多,人們不知道選擇哪種編輯器來提高工作效率。


          于我而言,除了使用Android Studio或使用Xcode的iOS所需的Android代碼外,我大多只使用Visual Studio Code。


          這是由Microsoft開發的編輯器。這是Microsoft開發的,聽起來不錯!!!幾乎支持所有語言,無數附加插件,AI代碼建議,漂亮的界面和淺色調(不是Sublime Text,但…仍然是淺色)


          過去,我只使用Sublime Text(當時不流行VSCode)。大量的插件(將在下文討論)為我節省了很多時間,例如自動檢測并修復錯誤,格式代碼,git鏡頭,終端等……,因為不再需要解決編碼時常見的小錯誤。


          如果編寫PHP,一定會喜歡PHPStorm。如果編寫Python,則一定會喜歡PyCharm。毋庸置疑,這些編輯器功能強大,但是,只支持一種語言。本人是一個全棧開發人員,具有JavaScript、HTML、PHP、NodeJS和React Docker的經驗...我使用的是VSCode,因為它功能非常強大,支持很多插件,尤其是自動完成功能非常不錯。


          對ESLint一見鐘情


          在語法錯誤上,我花費了最多時間,同時也最讓我沮喪,諸如未聲明變量/函數,空指針,缺少重音符號之類的錯誤……隨著代碼越來越多,一次必須讀取數十個文件,這很容易讓眼睛疲倦,頭腦一團亂,手也開始顫抖地鍵入每一行代碼,從而容易粗心大意并犯錯。


          在使用 ESLint時,這個插件可以幫助找出錯誤,檢查語法和格式代碼,因此能夠降低編碼時出現的漏洞,以及根據現行標準格式化時,能讓代碼看上去更好看。ESLint還支持其他許多老大哥:JavaScript,React,Vue等


          尤其是結合使用ESLint和VSCode,這搭配簡直完美。可以立刻檢查代碼鍵入,查看是否存在錯誤或語法問題,并提供有關如何使用函數和變量以實現最佳效果的建議。還有自動格式的代碼,你一定會喜歡上它。



          除了ESLint,還可以使用Prettier來格式化代碼,但是本人更喜歡ESLint,因為可支持錯誤檢測和提供最佳代碼建議。


          最佳目錄結構


          我最近開始“接受”并告訴自己一件事:


          不要從一開始就嘗試優化項目結構


          過去,開始著手一個項目時,不論項目或大或小,我總是會花很多時間選擇最佳的項目結構。我在谷歌上看了各種“ NodeJS文件夾結構的最佳實踐”,“ ReactJS代碼結構……”,但仍然想知道這個結構是否是最佳的,我應該選擇這個編碼框架嗎?這非常耗時。


          而且我還意識到,盡管起初我嘗試使用一種本來很好的結構,但是幾天后,代碼卻變得一團糟。因為我的系統思維不好,所以起初代碼寫得有多么漂亮并不重要,最后還是出問題了。


          不要過多地考慮選擇哪種架構,以及從一開始要如何去組織。選擇一個方向或一個庫、一個框架,并開始進行研究,一邊進行一邊改進,這樣更好也更實用。


          如果對結構良好的項目感興趣,我會分享一個名為NestJS的NodeJS框架,我閱讀了許多相關文檔,發現它們的體系結構非常好(非常類似于AngularJS,盡管我不太喜歡Angular)


          覺得代碼“壞掉”時,使用Console.log


          我很確定,console.log是我在編寫JavaScript時使用最多的。這一主要目的是查看感興趣的數據是否真實。

          來源:Pexels


          我個人認為,無論使用哪種語言,編程都離不開數據,因此如果看到任何令人不安的代碼,該代碼也許不正確,就應使用console.log進行確認。


          也有很多人認為調試器應該看起來更專業。谷歌還支持將Debug放在代碼行中,以獲得更好的了解。實際上,這對我個人而言不是必需的,console.log還會注意到代碼中的哪一行,使用console.log越快,就會更加方便。我還發現在臉書上的一些世界著名編碼專家,他們仍然使用console .log


          還應該注意到,console.log完成后,請檢查所有內容,然后再將其刪除,不要放在git上。這會讓人沮喪,看了眼睛疼(像我一樣)


          點評


          在編碼過程中,很多時候都需要冗長而復雜的代碼。人們擔心,經過很長一段時間再次閱讀這些代碼時,就可能不知道這段代碼是做什么的。或者懷著人道主義的心,希望以后閱讀這個代碼的人,可以明白代碼的作用。


          就個人而言,我發現寫評論真的很有用,尤其是該項目有很多人參與的時候。而且,我們不想每次不懂時,都跑去問寫這個代碼的朋友,而這個朋友也忙于修復測試人員布置的大量錯誤。而如果代碼本身可以解釋,那么之后看到該代碼的人就可以馬上就搞清楚,還能節省時間。


          但是評論也必須看起來合理舒適。不必評論所有內容。這有時會讓代碼難以閱讀,還讓人的眼睛很不舒服。


          在編寫代碼時,我會選擇變量/函數的名稱,便于理解,不要讓長的類/函數處理過多內容。相反,我會拆分成較小的類/函數(但不要拆分太多,拆分必須合理,不要再次讓人看著眼睛痛)。在需要時發表評論,練習編寫代碼,以便進行“自我解釋”。只需讀一讀,知道其中的作用即可。


          使用ES6、7、8、9標準


          JavaScript是一門快速發展的語言,另外還添加了許多強大的功能/庫。據我所知,每年人們都會發布名為ECMAScript或ES的JavaScript標準。這些標準中的每一個都包含著JavaScript內置的新功能。


          · 2015 ECMAScript 6(ES6)

          · 2016 ECMAScript 7(ES7)

          · 2015 ECMAScript 8(ES8)

          · 2015 ECMAScript 9(ES9)

          · 2015 ECMAScript 10(ES10)

          · ….

          因此,如果利用ECMA的強大功能,代碼將比僅使用傳統的for和if,while循環看起來更好,更加優化并且看上去更酷(就像本文的作者這般可愛)


          以下是我在編碼時最常用的一些函數/運算符:


          跳過 Promise / Callback,直接了解Async / Await


          Promise / CallbackWhile

          編碼的缺點是,我們必須大量使用API。從后端或第三方調用API以獲取數據和顯示時,需要執行以下操作:


          如果只想在成功檢索用戶列表之后才調用另一個API,那么通常需要執行以下操作:


          想按順序調用一系列API時,壞事就來了。當項目規模擴大,處理的請求越來越復雜時,這就是所看到的:


          Async / await 是救星


          自ES6(2015)起,async/await作為Promise/callbacks替代方法引入,用于處理異步操作。async / await的好處就在于有助于編寫看起來像同步的異步代碼,這些代碼逐行運行,看起來非常整潔。


          可以使用async / await重寫上面的代碼:


          有一些注意事項:


          · await總出現在async之后

          · 使用try / catch來捕獲異步函數中的錯誤處理操作

          · await的本質是等待Promise返回值,因此使用太多await有時會使應用變慢。


          使用async / await而不使用常規Promise / Callback的另一個好處是,使用try / catch可以發現async / await錯誤。還會發現try / catchblock中的所有其他錯誤,而不僅僅是async/await


          使用Typescript提高代碼質量


          故事開始了……


          我第一次進行編程用的是C語言,然后是Java。這些語言功能強大,需要極其嚴格的代碼,需要對數據類型(字符串,布爾值,…)或訪問規范(公共,私有,受保護的…)進行清晰完整的定義。那天我非常厭倦運行代碼,因為我不知道它是公共的還是私有的,數據類型是什么,于是就一直運行到報告錯誤為止。


          之后,開始使用JavaScript(或PHP,Python),無論數據類型如何,它都被大大簡化。只需聲明變量就可以使用:


          令x=

          1const test='This is a test'

          const arr=[1,2,3,4,5]


          這也是我從一開始就喜歡JS的一個原因,因為語法非常“自由”,不那么混亂,代碼看起來干凈漂亮。但是生活并不像夢想。漸漸地,我意識到,當項目有很多人編寫代碼之后,就會重新閱讀代碼。真的很糾結。因為我不知道這個變量是什么,該函數將返回什么類型的數據? …


          const var1=db.column1
          const var2=db.column2
          const var3=db.column3
          const var4=db.column4


          那現在怎么辦??當然是使用 console.log


          const var1=db.column1
          console.log(var1)//->string
          const var2=db.column2
          console.log(var2)//->boolean(true / false)
          const var3=db.column3
          console.log(var3)//- > number
          const var4=db.column4
          console.log(var4)//->array

          這只會浪費時間,未來我不太可能再來閱讀代碼,而且新的代碼讀者也不會理解。然后,我或是其他讀者必須做幾十個console.log語句才能理解,該代碼是用來做什么的?


          Typescript解決了這個問題


          在我看來,TypeScript是JavaScript的“升級版本”。現在,JavaScript代碼將具有明確定義的類型(字符串,布爾值,數字等),可訪問的訪問函數(公共,私有),……以及許多其他東西。Typescript編寫的代碼將被編譯成普通的JavaScript,因此可以照常運行,不需要專門的Typescript腳本或其他的東西。看一些例子:


          兩年前我聽說過TypeScript,但仍然不喜歡它,也不想使用,因為我只喜歡JavaScript的自由性。有時我想嘗試一下,但是我的眼睛很敏感,每次看到凌亂的東西時,眼睛就會更加敏感


          但是不久前,我決定改用TypeScript,因為我在閱讀舊代碼或其他人的代碼時,會遇到我提到的這一頭痛問題。而且,開發人員社區傾向于使用TypeScript,并進行很好地審查。


          當前,TypeScript在JavaScript開發人員中流行起來。庫或者框架(Angular,React或Vue)注重對TypeScript的支持。對于不知道的人:Vue 3絕對百分百是Typescript的重寫。同時,對于Microsoft開發的TypeScript,可以不用擔心質量和支持問題。


          CI / CD-代碼->測試->部署


          自動化測試

          請聽我說,您正在從事的項目遲早會崩潰的。最好的處理方法就是一邊做一邊改進,始終花20%的時間用于改進。并且唯一可以確保的方法就是在進行改進時,不會產生錯誤(或產生最少的錯誤),或編寫測試。


          要知道,甚至可以在編碼之前就編寫測試(Head First Java建議采用這種方式)


          CI / CD —持續測試和部署


          CI / CD(持續集成/持續集成),這是現在的趨勢,這種方法有助于自動連續地編寫代碼,進行測試和部署。


          實際上,幾乎所有CI / CD工具都已集成到Github,GitLab,BitBucket中。因此無需擔心,需要做的是設置然后推送代碼。DevOps平臺(Github,gitlab,存儲桶)會負責其余的工作。


          來源:Pexels


          希望大家閱讀完本文后可以學習并找到方法提高JavaScript編碼能力。


          同樣,如果你有什么提高JavaScript編碼能力的“妙招”,歡迎在評論區留言分享喲~

          留言點贊關注

          我們一起分享AI學習與發展的干貨

          如轉載,請后臺留言,遵守轉載規范

          言板是一個常見的Web應用程序,允許用戶在網站上發布和查看留言。在本文中,我們將使用PHP編寫一個簡單的留言板,介紹構建過程中的關鍵步驟和技巧。

          一、準備工作

          在開始編寫留言板之前,我們需要準備好以下工作:

          1、一個Web服務器環境,例如Apache或Nginx。

          2、PHP解釋器,確保PHP已經正確安裝和配置。

          3、一個MySQL數據庫,用于存儲留言信息。

          二、數據庫設計

          我們將使用MySQL數據庫來存儲留言信息。在數據庫中,我們需要創建一個表來存儲留言。下面是一個簡單的留言表設計:

          CREATE TABLE messages (
          id INT(11) AUTO_INCREMENT PRIMARY KEY,
          name VARCHAR(50) NOT NULL,
          email VARCHAR(50) NOT NULL,
          message TEXT NOT NULL,
          created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
          );

          這個表包含了id、name、email、message和created_at五個字段,分別表示留言的唯一標識符、留言者的姓名、郵箱、留言內容和留言創建時間。

          三、創建留言板頁面

          1、創建一個名為index.php的文件,并在文件中添加以下代碼:

          <!DOCTYPE html>
          <html>
          <head>
              <title>留言板</title>
          </head>
          <body>
              <h1>留言板</h1>
              <form action="submit.php" method="post">
                  <label for="name">姓名:</label>
                  <input type="text" name="name" id="name" required><br><br>
                  <label for="email">郵箱:</label>
                  <input type="email" name="email" id="email" required><br><br>
                  <label for="message">留言:</label><br>
                  <textarea name="message" id="message" rows="4" cols="50" required></textarea><br><br>
                  <input type="submit" value="提交">
              </form>
          </body>
          </html>

          一段代碼創建了一個簡單的HTML表單,用于用戶輸入姓名、郵箱和留言內容,并通過action屬性指定了提交表單時的處理頁面為submit.php。

          2. 創建一個名為submit.php的文件,并在文件中添加以下代碼:

          <?php
          // 連接數據庫
          $servername="localhost";
          $username="root";
          $password="password";
          $dbname="messages";
          $conn=new mysqli($servername, $username, $password, $dbname);
          // 檢查連接是否成功
          if ($conn->connect_error) {
           die("連接失敗: " . $conn->connect_error);
          }
          // 獲取表單數據
          $name=$_POST["name"];
          $email=$_POST["email"];
          $message=$_POST["message"];
          // 插入留言到數據庫
          $sql="INSERT INTO messages (name, email, message) VALUES ('$name', '$email', '$message')";
          if ($conn->query($sql)===TRUE) {
           echo "留言提交成功!";
          } else {
           echo "留言提交失敗:" . $conn->error;
          }
          // 關閉數據庫連接
          $conn->close();
          ?>

          這段代碼首先連接到數據庫,然后通過$_POST超全局變量獲取表單數據。接下來,將留言數據插入到數據庫表中,并根據插入結果輸出相應的提示信息。最后,關閉數據庫連接。

          四、顯示留言列表

          1、創建一個名為messages.php的文件,并在文件中添加以下代碼:

          <?php
          // 連接數據庫
          $servername="localhost";
          $username="root";
          $password="password";
          $dbname="messages";
          $conn=new mysqli($servername, $username, $password, $dbname);
          // 檢查連接是否成功
          if ($conn->connect_error) {
              die("連接失敗: " . $conn->connect_error);
          }
          // 從數據庫中獲取留言數據
          $sql="SELECT * FROM messages ORDER BY created_at DESC";
          $result=$conn->query($sql);
          // 輸出留言列表
          if ($result->num_rows > 0) {
              while($row=$result->fetch_assoc()) {
                  echo "<p><strong>姓名:</strong>" . $row["name"] . "</p>";
                  echo "<p><strong>郵箱:</strong>" . $row["email"] . "</p>";
                  echo "<p><strong>留言:</strong>" . $row["message"] . "</p>";
                  echo "<hr>";
              }
          } else {
              echo "暫無留言";
          }
          // 關閉數據庫連接
          $conn->close();
          ?>

          這段代碼首先連接到數據庫,然后從數據庫中獲取留言數據,并按照創建時間的倒序進行排序。接下來,通過循環遍歷每條留言,并將其輸出到頁面上。如果數據庫中沒有任何留言,將輸出"暫無留言"的提示信息。最后,關閉數據庫連接。

          2. 在index.php文件中添加一個鏈接到messages.php的超鏈接,以便用戶可以查看留言列表。在標簽中添加以下代碼:

          <a href="messages.php">查看留言</a>

          以上代碼可能存在bug,請使用過程中自行確認是否滿足要求。

          結論

          通過以上步驟,我們成功地使用PHP編寫了一個簡單的留言板。用戶可以在留言板上提交留言,并在留言列表中查看所有留言。這個留言板只是一個基礎示例,你可以根據實際需求進行擴展和改進。希望本文對你理解如何使用PHP構建留言板有所幫助!

          TML 支持有序、無序和定義列表:

          HTML 列表

          有序列表
          1. 第一個列表項
          2. 第二個列表項
          3. 第三個列表項
          無序列表
          • 列表項
          • 列表項
          • 列表項


          本例演示無序列表。
          無序列表

          有序列表

          本例演示有序列表。

          HTML無序列表

          無序列表是一個項目的列表,此列項目使用粗體圓點(典型的小黑圓圈)進行標記。

          無序列表使用 <ul> 標簽

          <ul>

          <li>Coffee</li>

          <li>Milk</li>

          </ul>

          瀏覽器顯示如下:

          • Coffee

          • Milk

          HTML 有序列表

          同樣,有序列表也是一列項目,列表項目使用數字進行標記。 有序列表始于 <ol> 標簽。每個列表項始于 <li> 標簽。

          列表項項使用數字來標記。

          <ol>

          <li>Coffee</li>

          <li>Milk</li>

          </ol>

          瀏覽器中顯示如下:

          1. Coffee

          2. Milk



          HTML 自定義列表

          自定義列表不僅僅是一列項目,而是項目及其注釋的組合。

          自定義列表以 <dl> 標簽開始。每個自定義列表項以 <dt> 開始。每個自定義列表項的定義以 <dd> 開始。

          <dl>

          <dt>Coffee</dt>

          <dd>- black hot drink</dd>

          <dt>Milk</dt>

          <dd>- white cold drink</dd>

          </dl>

          瀏覽器顯示如下:

          • Coffee

          • - black hot drink

          • Milk

          • - white cold drink

          注意事項 - 有用提示

          提示: 列表項內部可以使用段落、換行符、圖片、鏈接以及其他列表等等。

          更多實例

          不同類型的有序列表

          本例演示不同類型的有序列表。

          不同類型的無序列表

          本例演示不同類型的無序列表。

          嵌套列表

          本例演示如何嵌套列表。

          嵌套列表 2

          本例演示更復雜的嵌套列表。

          自定義列表

          本例演示一個定義列表。

          HTML 列表標簽

          標簽描述
          <ol>定義有序列表
          <ul>定義無序列表
          <li>定義列表項
          <dl>定義定義列表
          <dt>自定義列表項目
          <dd>定義自定列表項的描述

          如您還有不明白的可以在下面與我留言或是與我探討QQ群308855039,我們一起飛!


          主站蜘蛛池模板: 国产高清精品一区| 乱色精品无码一区二区国产盗| 精品无码人妻一区二区免费蜜桃| 亚洲高清一区二区三区| 精品无码人妻一区二区三区不卡| 男插女高潮一区二区| 日本不卡一区二区三区视频| 精品日韩一区二区| 亚洲国产高清在线精品一区| 中文乱码精品一区二区三区| 国产视频一区二区| 亚洲AV无码一区二区三区久久精品 | 亚洲av高清在线观看一区二区| 亚洲码欧美码一区二区三区| 无码欧精品亚洲日韩一区| 精品视频在线观看你懂的一区 | 狠狠综合久久av一区二区| 精品无人区一区二区三区| 国产免费一区二区视频| 成人免费av一区二区三区| 国产一区二区三区在线观看影院 | 精品国产一区二区三区色欲| 无码人妻精品一区二区三区东京热 | 久久se精品一区二区国产| 久久影院亚洲一区| 国产亚洲一区区二区在线| 国产精品福利区一区二区三区四区 | 中文字幕日韩丝袜一区| AV鲁丝一区鲁丝二区鲁丝三区| 人妻无码久久一区二区三区免费 | 国产福利91精品一区二区三区| 99久久人妻精品免费一区| 亚洲午夜一区二区电影院| 中文字幕av人妻少妇一区二区| 九九无码人妻一区二区三区| 国产精品福利一区| 久久无码精品一区二区三区| 亚洲国产成人一区二区精品区| 免费无码一区二区三区| 麻豆精品人妻一区二区三区蜜桃| 无码夜色一区二区三区|