質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

2回答

4619閲覧

カレンダーの作成について

退会済みユーザー

退会済みユーザー

総合スコア0

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

1クリップ

投稿2014/12/12 17:46

phpかjavascriptを使ってカレンダーの作成をしようと思っています。
調整さん」のようなカレンダーを作りたく質問させていただきました。
カレンダーの日にちをクリックしたらテキストとして、出力されるようなカレンダーです。

どこか参考になるサイトはありますでしょうか?

また、どのように書くのか教えていただきたいです。
抽象的な質問だとはわかっていますが、
どのように書いたらよいのか検討もつかないので、ご存知の方いらっしゃいましたら、ご教授願います。

現在、考えているのはjavascriptで
関数を作り、クリックされたらテキストに書き込まれるといった形をイメージしています。
しかし、次の月などの表記の仕方がわかりません。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

一度に大量のことを実現しようと詰め込みすぎです。順番に下から固めていきましょう。まずはカレンダーの生成アルゴリズムを理解しましょう。以下はPHPでの例ですが、JavaScriptでもほとんど同じように書けるはずです。

最もシンプルなカレンダー生成ロジック

その他参考になるページがこちらです。

JavascriptのDateオブジェクトの月(month)に注意
【覚書】JavaScriptでDateオブジェクトを使って一ヶ月の日数を得る
Create a JavaScript array containing 1…N
Split array into chunks

lang

1Array.prototype.chunk = function(size) { 2 var array = this; 3 return [].concat.apply([], array.map(function(e, i) { 4 return i % size ? [] : [array.slice(i, i + size)]; 5 })); 6} 7function range(min, max) { 8 return Array(max - min + 1).join().split(',').map(function(e, i) { 9 return min + i; 10 }); 11} 12function calendar(date) { 13 var dt = new Date(date.getYear(), date.getMonth(), 1); 14 var max = new Date(dt.getYear(), dt.getMonth() + 1, 0).getDate(); 15 var before = dt.getDay(); 16 var after = (7 - (before + max) % 7) % 7; 17 return range(1 - before, max + after) 18 .map(function (e) { return e < 1 || e > max ? '' : e; }) 19 .chunk(7); 20} 21var now = new Date; 22var cal_now = calendar(now);

次の月を表示するのであれば、単純に渡すDateオブジェクトに1ヵ月加算すればいいだけです。

lang

1var next = new Date(now.getYear(), now.getMonth() + 1, now.getDate()); 2var cal_next = calendar(next);

実際に表示してクリックしたときに反応させるにはイベントハンドラを使います。月の移動に関しては、クリックする要素自体は固定されるので、 .click() を使えばいいと思います。

.click()

各日にちに関しては、セルに共通のクラスを割り振っておいて、それに対してイベントハンドラを張ればいいと思います。動的に追加した要素に対しては.click()は使えないので、.on()を使う必要があります。

.on()

実際に情報をサーバ側に保存するには、$.ajax()を使ってPHP(もしくはnode.js/Python/Rubyなど)のスクリプトにデータを送信する必要があります。

$.ajax()
JavaScript(jQuery)からPHPのAPIを利用する

投稿2014/12/13 02:38

mpyw

総合スコア5223

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

jQueryUIを使うと楽そうです。
Datepicker

投稿2014/12/14 02:33

Lhankor_Mhy

総合スコア36074

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問