--- tags: JS 直播班 - 2023 秋季班 --- # 🏅 Day 45 - 關鍵字搜尋功能 請同學使用 [這個模板](https://codepen.io/hexschool/pen/bGKqbQQ?editors=1011) 進行練習,嘗試實作「關鍵字搜尋」的功能。 教學 --- 今天的每日任務並不在課程錄影範圍內,為加碼的知識分享,因此提供小教學讓大家做練習。關鍵字搜尋是蠻實用的技巧,同學可以直接觀看解答再自己練習看看。 ### match() 介紹([參考連結](https://developer.mozilla.org/zh-TW/docs/Web/JavaScript/Reference/Global_Objects/String/match)): > 1. match() 函式可以用來做字串的比對,分析關鍵字是否存在於字串當中。 > 2. 它是根據「[正規表達式](https://developer.mozilla.org/zh-TW/docs/Web/JavaScript/Guide/Regular_Expressions)」來進行實作的,有興趣的同學可以上網 Google,這邊就不詳細介紹正規表達式的運作方式。 > 3. 「關鍵字」可以是中 / 英文。如果關鍵字存在,則 match() 會回傳一個包含那個關鍵字的陣列; 如果關鍵字不存在,則 match() 會回傳 null。 > 4. 注意,關鍵字在字串中必須是「連續的」,像是以下範例的 keywordSeparate 就會回傳 null。 範例: ```javascript= // 想要用來比對的字串 let str = "我是 HexSchool 的大帥哥"; // 以下為 4 種關鍵字 let keywordChinese = "大帥哥"; let keywordEnglish = "HexSch"; let keywordNull = "不存在"; let keywordSeparate = "大哥"; console.log(str.match(keywordChinese)); // 回傳 ["大帥哥"] console.log(str.match(keywordEnglish)); // 回傳 ["HexSch"] console.log(str.match(keywordNull)); // 回傳 null console.log(str.match(keywordSeparate)); // 回傳 null ``` ### 教學開始(請搭配 [解答](https://codepen.io/hexschool/pen/rNKyBRO?editors=1011) 觀看) ### 步驟一:取得 input 的文字內容,並使用 trim()、toLowerCase() 做字串處理 > 1. .trim() 可以移除字串首尾的空白,避免發生錯誤; > 2. .toLowerCase() 可以把英文字母都轉成小寫,建議要比對的字串、關鍵字都做這項處理,這樣不管輸入的關鍵字英文字母大小寫為何,都能找到相符合的產品。 ### 步驟二:搭配 filter() 做篩選(JS 第 50 - 53 行) > 1. 設定「產品的標題」為欲比對的字串。 > 2. 設定 filter() 的 return 條件為「match() 的回傳值」。如果關鍵字存在,則 match() 會回傳一個陣列; 如果關鍵字不存在,則 match() 會回傳 null。 > 3. 在 JS 中,陣列為真值,會被轉換為 true; null 假值,會被轉換為 false ([參考連結](https://developer.mozilla.org/zh-CN/docs/Glossary/Truthy)) ### 步驟三:進行畫面渲染 ## 回報流程 將答案寫在 CodePen 並複製 CodePen 連結貼至底下回報就算完成了喔! 解答位置請參考下圖(需打開程式碼的部分觀看)  <!-- 解答: 請記得填入自己的 API 名稱 https://codepen.io/hexschool/pen/rNKyBRO?editors=1011 --> 回報區 --- | Discord | CodePen / 答案 | |:----------:|:-------------------------------------------------------:| | pinyi_9 | [Codepen](https://codepen.io/Wpypy/pen/xxMMeLV?editors=1011) | | 銀光菇 | [CodePen](https://codepen.io/genesynthesis/pen/oNmmOZY) | | 精靈 | [CodePen](https://codepen.io/justafairy/pen/dyaaLEZ) | | Ataraxia | [CodePen](https://codepen.io/ataraxia8888/pen/gOqqNMa) | | hsu0921 | [CodePen](https://codepen.io/HSUANIN0327/pen/rNPPEGZ) | | celinelinnn |[CodePen](https://codepen.io/celinephoebe/pen/MWLLMrG)| | Alyce |[CodePen](https://codepen.io/alycehwy/pen/NWooQXO?editors=1010)| | ⭐️小正 |[CodePen](https://codepen.io/colorgolden/pen/KKJJOmJ?editors=1011)| | Chia Pin |[CodePen](https://codepen.io/joker-cat/pen/xxMMvQR)| | Uli | [CodePen](https://codepen.io/uli1313/pen/qBgvWrp?editors=1011) | | kuanju27 | [CodePen](https://codepen.io/Eero-Chiao/pen/ExrMxaR) | | Celine 510 | [CodePen](https://codepen.io/Celine-510/pen/zYebYZJ) | | lychee_kk | [CodePen](https://codepen.io/kakakala/pen/JjxzoPj?editors=1011) | | kawa | [CodePen](https://codepen.io/z83xji6/pen/qBgvBZg?editors=1111) | | dora | [CodePen](https://codepen.io/dorayu/pen/ExrrzdQ) | |Moreene|[CodePen](https://codepen.io/Moreene/pen/abXMdwO)| | bf_tsai | [CodePen](https://codepen.io/BF-Tsai/pen/oNmVbMZ?editors=1111) | | xin | [CodePen](https://codepen.io/Estherrrrrr999/pen/xxMJyRx) | | yu.t_liu | [CodePen](https://codepen.io/YuT200053/pen/wvNOPOe?editors=1011) | | Ivy | [CodePen](https://codepen.io/Irene-Ke/pen/poGYOzK?editors=1010) | | 小夏 | [CodePen](https://codepen.io/michaelhsia/pen/VwgRVaR) | | 奔跑吧(GTR150) | [CodePen](https://codepen.io/Wer-Qwe/pen/zYebeYq?editors=1111) | | runweiting | [CodePen](https://codepen.io/weiting14/pen/mdvgPdX) | | Yijing | [CodePen](https://codepen.io/Yi-Jing-71080635/pen/eYXYYKm?editors=0011) | | ann6212 | [CodePen](https://codepen.io/yqmegupa-the-styleful/pen/YzgPWmx?editors=1011) | <!--快速複製 | Discord | [CodePen]() | -->
×
Sign in
Email
Password
Forgot password
or
By clicking below, you agree to our
terms of service
.
Sign in via Facebook
Sign in via Twitter
Sign in via GitHub
Sign in via Dropbox
Sign in with Wallet
Wallet (
)
Connect another wallet
New to HackMD?
Sign up