[精讚] [會員登入]
4610

[HTLM5] 表單時間日期date/time輸入類型

介紹HTML5和時間有關的輸入類型date/datetime/datetime-local/month/time/week

此文完整連結 http://n.sfs.tw/10309

複製連結 [HTLM5] 表單時間日期date/time輸入類型@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2016-11-27 21:48:42 最後編修
2016-11-27 11:16:31 By 瘦河馬
 

此系列文共分三部分,分別是

  [HTLM5] 表單color、email、url、search、tel輸入類型 
  [HTLM5] 表單date/time輸入類型
  [HTLM5] 表單number和range輸入類型

大家已知傳統表單input type有text, password, radio, checkbox等,例如一個登入的表單:

<input type="text" value="這是text類型" name="atextbox" />
<input type="password" value="這是password類型" name="atpassword" />

上面的input type有兩種,一個是text,另一個是password。這是傳統的種類,用起來很方便,但是html5有更方便類型,要知道善用:

  • color
  • date
  • datetime
  • datetime-local
  • email
  • month
  • number
  • range
  • search
  • tel
  • time
  • url
  • week

接下來介紹和時間有關的date/datetime/datetime-local/month/time/week 等類型。

date 類型

  <input type="date" name="bday">

Chrome長像

傳出的值
2016-03-01

datetime 類型

此類型已作廢,無瀏器支援

datetime-local 類型

 <input type="datetime-local" name="bdaytime">

Chrome長像
多一個時間的欄位可以輸入

傳出的值
2016-03-17T08:00

time 類型

 <input type="time" name="usr_time">

Chrome長像

傳出的值
23:01
02:58

month 類型

 <input type="month" name="bdaymonth" />

Chrome長像

傳出的值
2016-03

week 類型

 <input type="week" name="week_year">

Chrome長像

傳出的值
2016-W09
2016-W11

不支援html5的瀏覽器怎麼辦?

沒有支援html5的瀏覽器都會把這些類型當作是text輸出。

優缺點討論

以上有關時間的類型一出來,你有沒有覺得很興奮啊,不過我要告訴你們一個不幸的消息,就是IE及Firefox不支援:對這兩個瀏覽器來說,就只是一個單純的text欄位。也許使用者會放大訣說反正我只用chrome,但對網站的設計者來說,只要IE及Firefox不支援,這個type就形同作廢。還好有人有做了解決方法[2]。

不支援的瀏覽器處理方式

當不支援date等類型的瀏覽器需要使用日期選擇器(或時間選擇器)的話,可使用下面的判斷方法(以date舉例):

 if ( $('[type="date"]').prop('type') != 'date' ) {
  // 不支援date等類型的瀏覽器,類型是date 但是property不是'date'。
  // 在這裡放入其他的datetime picker,例如 jquery ui 的datetime picker
    $('[type="date"]').datepicker();
 }

參考資料

[1] W3C HTML5 Input type

[2] how-to-make-input-type-date-supported-on-all-browsers-any-alternatives


原文 2016-03-15 10:18:45

你可能感興趣的文章

[HTLM5] 表單時間日期date/time輸入類型 介紹HTML5和時間有關的輸入類型date/datetime/datetime-local/month/time/week

[HTLM5] html元件上的 data-* 屬性 html5 中元件中多了一個 data-*的屬性,這個屬性超級好用

UTF-8 BOM (Byte Order Mark) 的問題 在 Michael Kaplan 那看到 Every character has a story #4: U+feff

[HTML5] script 的新增屬性 defer, async script 的新增屬性 defer, async

[HTLM5] 表單color、email、url、search、tel輸入類型 介紹HTML5好用的輸入類型:color、email、url,以及兩個形同雞肋的類型search、tel..

CSS 的 !important 意義 網頁的前端工程師非常頭痛的事,就是同時要處理 IE和 FF等不同的瀏覽器,更糟的是 IE 又分成了 6 7 8三種版本,

關閉瀏覽器表單的自動完成autocomplete 什麼是自動完成?就是當我們在網頁的輸入文字欄位中打入文字時,瀏覽器會把曾輸入過歷史記錄中找出來讓我們選擇。

[CSS] 改變文字選擇的顏色(反選的顏色) 我們會用滑鼠選取一小段文字,可能是為了複製或是為了看他清楚點,這篇來改變他選擇時的背影色。

網頁的標頭(head)搜尋引擎和FB最佳化 網頁的標頭(head)搜尋引擎和facebook最佳化

[CSS] 多個 class 的表示法和寫法 網頁設計中常會用到CSS,他的一般格式是這樣的:

我有話要說


限制:留言最高字數1000字,超過部分會被截掉。 限制:未登入訪客,每則留言間隔需超過10分鐘,每日最多5則留言。

訪客留言

[無留言]

隨機好文

如何在linux下執行java 原生的java應用程式可以使用簡單的方法在console下面寫出來,適合作簡單的應用

為什麼要重造輪子? 什麼輪子?造什麼輪子?我為什麼要重造輪子?

一個邏輯的錯誤刪了全部檔案的經驗 今天本來想做一件很簡單的事,但卻足足浪費我多一倍的時間,再加上刪掉我全部的檔案,原因只是因為我自己的邏輯錯誤。

海棉寶寶超泡杯演奏的sweet victory 章魚哥和海棉寶寶在超泡杯的演奏歌曲

維修海棉拖把頭 這類型的海棉拖把很好用,可是這近發現海棉頭越來越不耐用,也許是錯覺,以往都能用個三四個月,現在二個月就差不多掉下來。 這