iT邦幫忙

0

想問 JS 的搜尋預覽作法

RIN 2021-11-21 14:48:071177 瀏覽
  • 分享至 

  • xImage

大大們好 我是JS小菜雞

目前想做搜尋功能, 預計想做出 當我搜尋關鍵字時、會跳出可以直接選取的正確關鍵字。
如下圖:
https://ithelp.ithome.com.tw/upload/images/20211121/20129506PQA6ygeDhI.png

參考網站:https://ibus.tbkc.gov.tw/ibus/route-search

小的目前在用原生 JS 進行網站開發。

但不知道這個功能的作法, google 時也不知道關鍵字該打什麼搜
想請大大們開示。

感激不盡。

看更多先前的討論...收起先前的討論...
Mao iT邦研究生 5 級 ‧ 2021-11-21 14:57:29 檢舉
HTML <datalist> Tag
我覺得 Autocomplete 比較符合你要問的
下面大大提供 W3C 也有 Autocomplete 的範例
Mao iT邦研究生 5 級 ‧ 2021-11-23 13:23:38 檢舉
我後來發現 datalist 標籤 跟 select 標籤的下拉選單沒辦法只透過 CSS 改樣式,我也有參加 The F2E ,才發現樣式問題
有樣式的 dropdown 通常都是用 div 去做的 XD
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

2 個回答

2
Felix
iT邦研究生 2 級 ‧ 2021-11-21 17:10:41

關鍵字:Filterable ComboBox

Mao 說的 datalist 是不錯的選擇,有 90.82% 的瀏覽器完全支援

如果想要自訂樣式,您可以選擇 OO.ui.ComboBoxInputWidget預覽效果) 。

如果想要享受實作的成就感,您可以參考:

  1. W3Schools
  2. Stack Overflow

題外話,日本語 N1 是我達不到的境界呢!

2
海綿寶寶
iT邦大神 1 級 ‧ 2021-11-21 17:36:31

你看到的是 UI 的使用效果
依據「資料在那裡」,有兩種做法:
1.資料在Browser端
W3School有易懂範例
2.資料在Server端(高雄公車動態資訊網站的做法)
使用者輸入關鍵字(例:美麗島)
向server發送詢問請求

https://ibus.tbkc.gov.tw/ibus/graphql

{"operationName":"QUERY_STATIONS_NAMES_BY_VALUE","variables":{"lang":"zh","name":"美麗島"},"query":"query QUERY_STATIONS_NAMES_BY_VALUE($name: String!, $lang: String!) {\n  stationsByName(name: $name, lang: $lang) {\n    edges {\n      node {\n        id\n        name\n        lat\n        lon\n        __typename\n      }\n      __typename\n    }\n    __typename\n  }\n}\n"}

得到回覆如下

{"data":{"stationsByName":{"edges":[{"node":{"id":"2295","name":"捷運美麗島站","lat":22.630165100097656,"lon":120.30191802978516,"__typename":"StationItem"},"__typename":"StationListEdge"},{"node":{"id":"2296","name":"捷運美麗島站","lat":22.630416870117188,"lon":120.30164337158203,"__typename":"StationItem"},"__typename":"StationListEdge"},{"node":{"id":"3376","name":"郵政總局(捷運美麗島站)","lat":22.630599975585938,"lon":120.30455780029297,"__typename":"StationItem"},"__typename":"StationListEdge"},{"node":{"id":"3377","name":"郵政總局(捷運美麗島站)","lat":22.63055992126465,"lon":120.3042984008789,"__typename":"StationItem"},"__typename":"StationListEdge"},{"node":{"id":"4552","name":"美麗華大廈","lat":22.568531036376953,"lon":120.36581420898438,"__typename":"StationItem"},"__typename":"StationListEdge"},{"node":{"id":"4553","name":"美麗華大廈","lat":22.568729400634766,"lon":120.3655776977539,"__typename":"StationItem"},"__typename":"StationListEdge"}],"__typename":"StationListConnection"}}}

再把回覆顯示成 dropdownlist

我要發表回答

立即登入回答