勉強したことのメモ

webプログラマ見習いが勉強したことのメモ。

日付入力のテキストフォームにカレンダープラグインを導入

      2014/02/23

やりたかった事と制限は下記の通り。

・日付入力のテキストフォームにカレンダープラグインを導入
・jQueryUIは使わない
・出来るだけ軽いもの

■使用プラグイン
http://glad.github.io/glDatePicker/

■使い方
jsファイルとCSSファイルを呼び出す。
jQuery部分に、
$(function(){
    $("テキストフォームIDを指定").glDatePicker();
})
と記述するだけ。

■ソース
<!DOCTYPE HTML>
<html lang="ja">
<head>
<meta charset="UTF-8">
<title>glDatePickerの練習</title>
<link rel="stylesheet" href="./styles/glDatePicker.default.css" type="text/css">
<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script type="text/javascript" src="./glDatePicker.min.js"></script>
<script>
    $(function(){
        $("#calender1,#calender2").glDatePicker({
            onClick: function(target, cell, date, data) {
                target.val(date.getFullYear() + '/' + (date.getMonth()+1) + '/' +date.getDate());
            }
        });
    });
</script>
</head>
    <body>
    <h1>glDatePickerの練習</h1>
    <input type="text" id="calender1"> ~ <input type="text" id="calender2">
    </body>
</html>

■サンプル
http://sample.taitan916.info/calender/

■その他
複数設置したい時は$("#calender1,#calender2").glDatePicker
みたいにカンマ区切りで指定。

あとデフォだとブラウザの仕様かもしれないけど、

IE,Firefox ⇒ YYYY/MM/DD
Chrome ⇒ YYYY年MM月DD日

みたいなフォーマットになった。受け取る際に正規表現使えば
いけそうだけどフォーマット揃えといた方が何かとよさそうなので、

{onClick: function(target, cell, date, data) {
target.val(date.getFullYear() + '/' + (date.getMonth()+1) + '/' +date.getDate());
}

の部分でスラッシュ区切りを指定している。
この方法が正しいかどうかは知りません。

date.getMonth()はすっかり忘れてたけど+1しないと

いけないので注意。

//追記

付属しているCSSでデザイン変えるのが上手くいかず

悩んだのでメモ。jqueryで書く時に「cssName: 'flatwhite', 」

みたいにクラス名をつけることで解決。

 - javascript, jQuery

  関連記事

mzl.qobqfuxq
GoogleMapでマーカーをまとめる

GoogleMapAPIでマーカーを複数表示し、近隣のエリアごとにまとめて表示さ ...

jquery_logo
jQueryで高速化

高速化について調べる機会があったのでメモ。 ------ ・セレクタはclass ...

javascript_logo_unofficial-300x300
jQueryやJavaScriptで認識違いしていたところのメモ(高速化)

認識違いしていたり、知らなかったりでもっと高速な 処理を行えそうな点があったので ...

jquery_logo
jQueryでセレクトメニューにcheckedをつける

セレクトメニュー(セレクトボックス)で特定の項目をデフォルトで選択しておきたかっ ...

javascript_logo_unofficial-300x300
table内のiframeのheightを最大高さにする

tableのtdの中にリンクがあり、クリックすると td内でiframeが開く。 ...

jquery_logo
jQueryの最新バージョン呼び出しとバージョン確認

<script type="text/javascript" src="h ...

110126-HTML5_Logo
formでdisplay:none;にしてても送信される

formで特定の部分をdisplay:none;で非表示にしてても 内容は送信さ ...

javascript_logo_unofficial-300x300
JavaScriptでcookieの保存

JavaScriptでcookieを保存したかったけど 方法が分からなかったので ...

flash_player_11_icon_rgb
FlashとjQueryを組み合わせたプラグインでWebカメラで撮影した画像をアップロード

FlashとjQueryを組み合わせたプラグインを用いてWebカメラで撮影した画 ...

mzl.qobqfuxq
PHPで位置情報を取得してGoogleMapAPIで使用する方法

GPSみたいな位置情報をPHPで取得し、GoogleMapAPIでその場所を反映 ...