Upload
katsuyuki-seino
View
4.163
Download
9
Embed Size (px)
Citation preview
111
AjaxによるWebアプリケーション開発講座
[応用コース]
(有)サイバースペース
CyberSpaceTechnology Holdings
http://www.at21.net/
清野 克行1
2 2 2
Ajax実践編
Ajax要素技術の応用 1.テーブルの参照・登録・更新・削除 イベントの伝播、DOMノード操作、DB登録 2.部品構成(任意の構成)の一括表示 再帰呼出しでの非同期通信 GET/同期、prototype.jsの制限 3.Ajaxでのコールバック処理 タイマ-での擬似コールバック Ajax コールバック例 (777マッチ) 受注情報登録とコールバック表示
Ajaxライブラリ 1.ActiveWidgets 簡単なサンプル 実習-1 タブコントロール ツリーコントロール コンボボックス 演習-1 グリッドコントロール 実習-2 演習-2 演習-3 2.DWR (Direct Web Remoting) DWRの特徴 DWRサンプル 実習-3 DWRプログラミング 演習-4 演習-5 3.Plotr 実習 4.script.aculo.us 演習-6 5.Yahoo! UI Library 演習-7
3 3 3
Ajax要素技術
概論
Ajax(Asynchronous JavaScript + XML)=A New Approach to Web Applications 2005年2月18日 adaptive pathの Jesse James Garrett のエッセイに初登場
Ajaxの始まり
5 5 5
XML
DB プレゼンテーション
Web UI
AjaxモデルでのWebシステム (SPI=Single Page Interface)
Webクライアント CGI系プログラム
ビジネスロジック
ユーザPC サーバサイド
データアクセス
Ajaxエンジン
Webブラウザ
GET/POST
テキスト XML
データストア
Web
GUI
Ajaxエンジンの機能
Ajaxエンジン
⑤ 演算処理 ④ 表示制御
サーバ
① イベント処理
② サーバ通信
③ UI表示
JavaScript
XHTML+CSS ・XHTML 画面構成 ・CSS 表示制御
・テキストデータ ・XMLデータ
Ajax初めてのプログラム - Ajaxサンプルプログラム1
従業員番号から氏名表示 操作手順]
1.従業員番号入力 ↓ 2.カーソル移動 ↓ 3.従業員氏名表示
<script type="text/javascript" src=”../funcs.js"></script> <script type="text/javascript"> //<![CDATA[ function getEmpName(){ var emp_no = document.getElementById("emp_no").value; var httpObj = getHttpObject(); httpObj.open(“get", "sample1.php?emp_no=" + emp_no); httpObj.send(null); httpObj.onreadystatechange = function(){ if(httpObj.readyState == 4){ if(httpObj.status == 200){ var emp_name = httpObj.responseText; document.getElementById("emp_name").value = emp_name; } } } } //]]> </script>
GET/非同期での受信処理
Ajaxでの通信方式(GET/POST;非同期/同期)
<script type="text/javascript"> //<![CDATA[ var httpObj; function getEmpName(){ var emp_no = document.getElementById("emp_no").value; httpObj = getHttpObject(); httpObj.open("get", "sample1.php?emp_no=" + emp_no); httpObj.send(null); httpObj.onreadystatechange = getEmpNameRv; } function getEmpNameRv(){ if(httpObj.readyState == 4){ if(httpObj.status == 200){ var emp_name = httpObj.responseText; document.getElementById("emp_name").value = emp_name; } } } //]]> </script>
GET/非同期-関数名指定での受信処理
<script type="text/javascript"> //<![CDATA[ function getEmpName(){ var emp_no = document.getElementById("emp_no").value; var httpObj = getHttpObject(); httpObj.open("get", "sample1.php?emp_no=" + emp_no, false); httpObj.send(null); document.getElementById("emp_name").value = httpObj.responseText;; } //]]> </script>
GET/同期
<script type="text/javascript"> //<![CDATA[ function getEmpName(){ var emp_no = document.getElementById("emp_no").value; var httpObj = getHttpObject(); httpObj.open("post", "sample1p.php", true); httpObj.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); httpObj.send("emp_no="+emp_no); httpObj.onreadystatechange = function(){ if(httpObj.readyState == 4){ if(httpObj.status == 200){ var emp_name = httpObj.responseText; document.getElementById("emp_name").value = emp_name; } } } } //]]> </script>
POST/非同期
<script type="text/javascript">
//<![CDATA[
function getEmpName(){
var emp_no = document.getElementById("emp_no").value;
var httpObj = getHttpObject();
httpObj.open("POST", "sample1p.php", false);
httpObj.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
httpObj.send("emp_no="+emp_no);
var emp_name = httpObj.responseText;
document.getElementById("emp_name").value = emp_name;
}
//]]>
</script>
POST/同期
サーバからの受信データがテキスト並びの場合
サーバからの受信データがテキスト並びの場合、
受信データはsplitメソッドで配列にセットし、
htmlタグと組合せ、表示用タグ構成を作成・出力。
// JavaScript var rv = httpObj.responseText.split("<i>"); var out = ‘<table>’; for(i = 0; i < rv.length; i++ ){ out += "<tr><td>" + i + "</td><td>" + rv[i] + "</td></tr>"; } out += "</table>"; document.getElementById("area1”).innerHTML = out; // xhtml <p id=”area1”>表示領域</p>
var rows = httpObj.responseText.split("<r>"); for(i = 0; i < rows.length; i++ ){ var row = rows[i].split("<i>"); for(i = 0; i < row.length; i++ ){ : //xhtmlタグ作成 : } } document.getElementById("area1”).innerHTML = out; //outは作成されたxhtmlタグ構成
データベース検索結果の表示
(複数レコード)
・レコード単位で配列にセットし
(rows[i])
・各レコードのアイテム単位で表示
をタグ作成
http://www.prototypejs.org
・Ajaxフレームワーク ・JavaScript言語機能強化 ・メソッド名ショートカット ・DOM操作機能の拡張 ・クロスブラウザ対応 ・ MIT License
prototype.js
MIT License
※MIT License ・このソフトウェアを誰でも無償で無制限に扱うことができる。但し、著作権表示および本許 諾表示を、ソフトウェアのすべての複製または重要な部分に記載しなければならない。 ・作者または著作権者は、ソフトウェアに関してなんら責任を負わない。
//<![CDATA[ function revClass1(){ var set = "class1_code=" + $("class1_code").value; new Ajax.Request('revClass1.php', {method:'get', onComplete:out, parameters:set}); } function out(get){ var row = get.responseText.split("<i>"); $("status", "class1_name", "class1_desc", "class1_date").each(function(obj){ obj.innerHTML = row.shift(); }); } function listeners(){ addListener($("rev"), "click", revClass1, false); } addListener(window, "load", listeners, false); //]]>
revClass1.js(prototype.js:Ajax.Request)
prototype.jsでの通信
//<![CDATA[ function addClass1(){ new Ajax.Updater({success:'status',failure:'status'}, 'addClass1.php', {method:'post', postBody:Form.serialize("items")}); } function setListeners(){ addListener($("add"), "click", addClass1, false); } addListener(self, "load", setListeners, false); //]]>
addClass1.js(prototype: Ajax.Updater)
Ajax.RequestとAjax.Updaterの使い分け ・Ajax.Request 受信データのプログラム処理を想定 ・Ajax.Updater 受信データの直接表示を想定(container)
※出力用の関数指定なし
Web
GUI
Ajaxエンジンの機能
Ajaxエンジン
⑤ 演算処理 ④ 表示制御
サーバ
① イベント処理
② サーバ通信
③ UI表示
JavaScript
XHTML+CSS ・XHTML 画面構成 ・CSS 表示制御
・テキストデータ ・XMLデータ
ルート
キャプチャフェーズ
バブリングフェース オブザーバ
ターゲット
document
table
tr
td
DOMイベントモデル
・ターゲット イベント発生
・オブザーバ イベントキャッチ
・バブリングフェーズ
イベントの上位伝播
・キャプチャフェーズ
イベントの下位伝播
イベント発生
イベントキャッチ
tbody
function revClass1(e) { 処理内容 } function setListeners() { var observer = document.getElementById(“show"); addListener(observer, "click", revClass1); } setListener(window, "load", setListeners);
イベントオブジェクト イベントオブジェクトからイベントに関する様ざまな情報を所得可能
・キー入力、マウスクリックでのイベント発生ノード識別
・キー入力イベントでの入力キー識別(キーコード値)
・マウスクリックイベントでのマウスボタン(左、右、中央)識別
・マウスポインタ(カーソル)移動でのポインタ位置検出
イベントターゲットの検出: getid(e)
イベントターゲット(イベント発生ノード) → idタグで識別
IE系ブラウザ e.srcElement IE以外のブラウザ e.target
function getid(e){ var tgt; if(!e) var e = window.event; if(e.srcElement){ // Microsoft tgt = e.srcElement.id; if(tgt.nodeType == 3) tgt = tgt.rapentNode; }else if(e.target){ // W3C/Netscape tgt = e.target.id; }else{ tgt = false; } return tgt; }
getid関数(funcs.js)
イベント発生ノードを
返す。
function getkcode(e){
if(!e) var e = window.event;
if(e.keyCode){
return e.keyCode;
}else if(e.which){
return e.which;
}else{
return false;
}
}
getkcode関数(funcs.js)
キー入力イベントで
入力キーコード値を返す
IE系および新しいFireFox e. keyCode 古いFireFox e.which
入力キーコードの検出: getkcode(e)
クリックマウスボタン(左右)の検知
FireFox 関数:e.which
•Left button: 1
•Middle button: *
•Right button: 3
MS(IE) 関数:e.button
•Left button: 1
•Middle button: *
•Right button: 2
function mbutton(e){
var click;
if(!e) var e = window.event;
if (e.which){
if(e.which == 1){
click = "L";
}else if(e.which == 3){
click = "R";
}
}else if (e.button){
if(e.button == 1){
click = "L";
}else if(e.button == 2){
click = "R";
}
}else{
click = "F";
}
return click;
}
クリックマウスボタンの検出 mbutton(e)
・左ボタンクリック → 戻り値(“L”) ・右ボタンクリック → 戻り値(“R”)
1. e.clientX、 e.clientY [IE,FF] 原点(0,0):ブラウザ画面左上 e.clientX: ウィンドウ表示部分の左上を基準としてX座標をピクセル値で返す。 e.clientY: ウィンドウ表示部分の左上を基準としてY座標をピクセル値で返す。 2. e.offsetX、 e.offsetY [IEのみ] e.offsetX: イベントでオフセットの親となるoffsetParentオブジェクトの左上を 基準としてオブジェクトのX座標をピクセル値で返す。 e.offsetY: イベントでオフセットの親となるoffsetParentオブジェクトの左上を 基準としてオブジェクトのY座標をピクセル値で返す。 3. e.screenX、 e.screenY [IE,FF] 原点(0,0):モニタ画面左上 e.screenX: スクリーン上マウス位置のX座標をピクセル値で返す。 e.screenY: スクリーン上マウス位置のX座標をピクセル値で返す。 4. e.x、 e.y [IEのみ、e.clientX、 e.clientYと同じ] e.x: ウィンドウ表示部分の左上を基準としてX座標をピクセル値で返す。 e.y: ウィンドウ表示部分の左上を基準としてY座標をピクセル値で返す。
移動するマウスポインタ位置の検出
マウスポインタ位置の検出
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>マウスボタン </title> <style> <!-- #area {position: absolute; background-color: #eeeeee; top: 5px; left: 5px; width: 300px; height: 300px;} #stat {position: absolute; top: 35px; left: 315px;} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA[ function check(e){ document.getElementById("x1").value = e.clientX; document.getElementById("y1").value = e.clientY; document.getElementById("x2").value = e.screenX; document.getElementById("y2").value = e.screenY; }
マウスポインタ位置の検出 mpos2.htm 1/2
以後省略
function initOnLoad(){ var observer = document.getElementById("area"); setListener(observer, "mousemove", check); } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> <div id="area"></div> <div id ="stat"> <h4>マウスポインタ位置の検出</h4> <ul type="circle"> <li>e.clientX_<input type="text" size="5" id="x1" /></li> <li>e.clientY_<input type="text" size="5" id="y1" /></li> </ul> <ul type="circle"> <li>e.screenX<input type="text" size="5" id="x2" /></li> <li>e.screenY<input type="text" size="5" id="y2" /></li> </ul> </div> </body> <//html>
mpos2.htm 2/2
//<![CDATA[ function check(e){ document.getElementById("x1").value = e.clientX; document.getElementById("y1").value = e.clientY; document.getElementById("x2").value = e.screenX; document.getElementById("y2").value = e.screenY; } function initOnLoad(){ var observer = document.getElementById("area"); setListener(observer, "mousemove", check); } setListener(window, "load", initOnLoad); //]]>
mpos2.js
フォーム
コントロール
・ラジオボタン ・チェクボックス ・セレクトメニュー 必要性:Ajaxでのコントロールデータ処理と送信 メリット:サーバレスポンスデータでの動的値設定 動的絞り込み検索
セレクトメニュー
<style> <script type="text/javascript" src="../funcs.js"></script> <script type="text/javascript" src="selectMenu.js"></script> </head> <body> <h3>セレクトメニューの選択確認</h3> <p> <select id="pc"> <option value="SEL" id="sel"><=選択=></option> <option value="CPU" id="cpu">CPU</option> <option value="RAM" id="ram">メモリ</option> <option value="HDD" id="hdd">ハードデスク</option> <option value="DVD" id="dvd">DVD</option> </select> </p><hr /> <p id="result"></p> </body> </html>
selectMenu.htm
//<![CDATA[ function checkSpec(){ var source = document.getElementById("pc").value; document.getElementById("result").innerText = "選択結果: " + source; } Function listeners(){ var observer = document.getElementById("pc") setListener(observer, "change", checkSpec); } setListener(window, "load", listeners); //]]>
selectMenu.js
//<![CDATA[ function checkSpec(){ $(“result”).innerText = “選択結果: ” + $F("pc“); Function listeners(){ setListener($(“pc”), "change", checkSpec); } setListener(window, "load", setListeners); //]]>
Prototype.js
セレクトメニュー 絞り込み検索
<link type="text/css" rel="stylesheet" href="../lib/style.css"/>
<script type="text/javascript" src="../lib/funcs.js"></script>
<script type="text/javascript" src="../lib/prototype.js"></script>
<script type="text/javascript">
//JavaScript
</script>
</head>
<body>
<center class="t3">Select Menu2</center>
<table width="440" align="center">
<tr>
<td width="90" align="right">クラス1項目</td>
<td width="130" id="class1">
<select><option value="">-----クラス1選択-----</option></select>
</td>
<td width="90" align="right">クラス2項目</td>
<td width="130"id="class2">
<select><option value="">-----クラス2選択-----</option></select>
</td>
</table>
</body>
</html>
selectMenu2.htm 1/4
//<![CDATA[
var httpObj = getHttpObject();
function getClass1(){
httpObj.open('get', 'getClass1Sel.php', false);
httpObj.onreadystatechange = getClass1Rv;
httpObj.send(null);
}
function getClass1Rv(){
if(httpObj.readyState == 4){
if(httpObj.status == 200){
var resRows = httpObj.responseText.split("<p>");
var out = '<select id="class1List">'
+ '<option value="">----クラス1選択----</option>';
for(i = 0; i < resRows.length; i++){
var resRow = resRows[i].split(",");
for(j = 0; j < resRow.length; j++){
if(j==0){
class1_code = resRow[j];
}else{
out += '<option value=' + class1_code + '>' + resRow[j] + '</option>';
}
}
}
out += '</select>';
$("class1").innerHTML = out;
}
}
}
selectMenu2.htm 2/4
function getClass2(){
var class1_code = $("class1List").value;
httpObj.open('get', 'getClass2Sel.php?class1_code='+class1_code, false);
httpObj.onreadystatechange = getClass2Rv;
httpObj.send(null);
}
function getClass2Rv(){
var i, j, resRows, resRow, out, out3, code;
if(httpObj.readyState == 4){
if(httpObj.status == 200){
resRows = httpObj.responseText.split("<p>");
out = '<select id="class2List">'
+ '<option value="">---クラス2選択済---</option>';
for(i = 0; i < resRows.length; i++){
resRow = resRows[i].split(",");
for(j = 0; j < resRow.length; j++){
if(j==0){
class2_code = resRow[j];
}else{
out += '<option value=' + class2_code + '>' + resRow[j] + '</option>';
}
}
}
out += '</select>';
$("class2").innerHTML = out;
addListener($("class2List"), "change", getClass3, false);
}
}
}
selectMenu2.htm 3/4
function getClass3(){
alert($("class2List").value);
}
Function listeners(){
setListener($("class1List"), "change", getClass2);
}
setListener(window, "load", listeners);
setListener(window, "load", getClass1);
selectMenu2.htm 4/4
ラジオボタン
<script type="text/javascript" src="funcs.js"></script> <script type="text/javascript" src="radioBtn.js"></script> </head> <body> <h3>ラジオボタンの選択確認</h3> <p id="pc"> <input type="radio" id="cpu" />cpu <input type="radio" id="ram" />メモリ <input type="radio" id="hdd" />ハードデスク <input type="radio" id="dvd" />DVD </p> <hr /> <p id="result"></p> </body> </html>
radioBtn.htm
//<![CDATA[ Var xhrObj = getXhrObj(); function checkSel(e){ var sel = getid(e); id("result").innerText = "選択結果: " + sel; } Function initOnLoad(){ setListener(id(“pc”), "click", checkSel); } setListener(window, "load", initOnLoad); //]]>
radioBtn.js
チェックボックス
<?xml version="1.0" encoging="utf-8"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <title>チェックボックス</title> <link rel="stylesheet" type="text/css" href=“../lib/style.css" /> <script type="text/javascript" src=”../lib/funcs.js"></script>
<script type="text/javascript" src="checkB.js"></script> </head> <body> <p id="pc"> <input type="checkbox" id="display" />ディスプレイ <input type="checkbox" id="mouse" />マウス <input type="checkbox" id="keybord" />キーボード <input type="checkbox" id="dvd" />DVDドライブ </p> </body> </html>
チェックボックス選択確認XHTML checkB.htm
チェクボックス選択確認JavaScript checkB.js
//<![CDATA[ function checked(e){ var eid =getid(e); alert("選択は " + eid); } function setListeners(){ setListener($("pc"), "click", checked); } setListener(window, "load", setListeners); //]]>
チェックボックス-複数選択での処理
<link rel="stylesheet" type="text/css" href="style.css" /> <script type="text/javascript" src="funcs.js"></script> <script type="text/javascript" src="checkBox.js"></script> </head> <body> <p id="pc"> <input type="checkbox" id="display" />ディスプレイ <input type="checkbox" id="mouse" />マウス <input type="checkbox" id="keybord" />キーボード <input type="checkbox" id="dvd" />DVDドライブ <br /><br /> <button type="button" class="b2" id="confirm">受信確認</button> </p><hr /> <table> <tr><td>選択確認</td><td id="result1"></td></tr> <tr><td>選択累積</td><td id="result2"></td></tr> <tr><td>受信確認</td><td id="result3"></td></tr> </table> </body> </html>
checkBox.htm
//<![CDATA[ var optcum = new Array(); var options = new Array(); function checked(e){ var eid =getid(e); optcum.push(eid); document.getElementById("result1").innerText = eid; document.getElementById("result2").innerText = optcum; } function confirm(){ for(var i = 0; i < optcum.length; i++){ if(document.getElementById(optcum[i]).checked == true) options.push(optcum[i]); } var httpObj = getHttpObject(); httpObj.open("post", "../checkbox", false); httpObj.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); httpObj.send("options=" + options); out = httpObj.responseText; document.getElementById("result3").innerHTML = out; } Function listeners(){ var observer1 = document.getElementById("pc"); setListener(observer1, "click", checked); var observer2 = document.getElementById("confirm"); setListener(observer2, "click", confirm,); } setListener(window, "load", listeners); //]]>
checkBox.js
package domevent; import java.io.*; import javax.servlet.*; import javax.servlet.http.*; public class checkBox extends HttpServlet { public void doPost (HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException { int i; String options[] = req.getParameterValues("options"); PrintWriter out; res.setContentType("text/html; charset=Shift_JIS"); out = res.getWriter(); for (i = 0; i < options.length - 1; i++){ out.println(options[i] + ","); } out.println(options[i]); out.close(); } }
checkBox.java
Web
GUI
Ajaxエンジンの機能
Ajaxエンジン
⑤ 演算処理 ④ 表示制御
サーバ
① イベント処理
② サーバ通信
③ UI表示
JavaScript
XHTML+CSS ・XHTML 画面構成 ・CSS 表示制御
・テキストデータ ・XMLデータ
httpObj.onreadystatechange = function(){ if(httpObj.readyState == 4){ if(httpObj.status == 200){ finalItems = httpObj.responseText.split(","); //for(i in finalItems){ prototype.jsで副作用 for(i = 0; i < finalItems.length; i++){ tagNode = document.createElement("p"); tagNode.setAttribute("id", finalItems[i]); docNode = document.createTextNode('[0] '+finalItems[i]); tagNode.appendChild(docNode); document.getElementById("tree").appendChild(tagNode); } } } }
(1) DOMノード操作サンプル
DOMノード操作
DOMノード操作概要
ノードの種類 ・要素ノード (element node) ・属性ノード (attribute node) ・テキストノード(text node)
<div id=“id1” class=“class1”>DOMノード操作</div>
要素ノード <div>
テキストノード DOMノード操作
属性ノード id=“id1” class=“class1”
例]
getElementById
構文] object.getElementById(“id属性値”) 機能] 指定したID名を持つ要素ノードオブジェクトを返す。 引数] id属性値。 返値] オブジェクト。 適用] document 対応] [IE5~][Firefox1~][Safari1~][Opera8~][Netscape6~]
1.要素ノードの参照
※非常に頻繁に使用されるメソッドで、多くのAjaxライブラリでショートカット
関数が用意されている。
例] document.getElementById(“out1”);
↓
$(“out1”); // Prototype.js, DWR
id(“out”); // funcs.js
getElementsByTagName
構文] object. getElementsByTagName(“タグ名”) 機能] 指定したタグ名を持つオブジェクト(要素ノード)を配列形式で返す。 引数] タグ名。 返値] オブジェクトの参照。 適用] document 対応] [IE5~][Firefox1~][Safari1~][Opera8~][Netscape6~]
要素ノードの参照
※ワイルドカード “*” で総てのノード要素を指定することが出来る。 ※funcs.jsでショートカット関数が用意されている。 例] document.getElementsByTagName(“div”);
↓
tn(“div”); // funcs.js
getAttribute
書式] object.getAttribute('attributeName‘ [, 'type‘]) 説明] オブジェクトの指定された属性の値を返す。 引数] attributeNameは属性の名前を指定。 typeは種類を指定。次のいずれか。 0(アトリビュート名の大文字小文字の区別をしない) 1(アトリビュート名の大文字小文字の区別をする) 2(値を返す) 返値] アトリビュートの値 対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
2.属性ノードの参照
getAttributeNode
構文] object.getAttributeNode('attributeName') 説明] オブジェクトの指定された属性のノード値を返す。 引数] AttributeNameは属性名を指定。 返値] attributeオブジェクトを返す。 対応] [IE5~][Firefox1~][Safari1~][Opera8~][Netscape6~]
属性ノードの参照
firstChild
書式] object.firstChild 説明] オブジェクトの最初の子ノードを参照する。 firstChildはchildNodes[0]と同じになる 対応] IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
lastChild
書式] object.firstChild 説明] オブジェクトの最後の子ノードを参照する。 firstChildはchildNodes[object.childNodes.length-1]と同じになる 対応] IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
子ノードの参照-1
childNodes
構文] object.childNodes object.childNodes[index] object.childNodes.length 機能] オブジェクトの子ノードを参照する。 評価値は配列で最初の子ノードは0番になる。 引数] id属性値。 返値] 子ノードオブジェクトの配列 適用] object 対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
子ノードの参照-2
hasChildNodes 構文] object.hasChildNodes() 機能] 子ノードがあるかどうか返す。 子ノードがある場合はtrue、ない場合はfalseを返す。 引数] id属性値。 返値] 真偽値 適用] object 対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
子ノードの参照-3
function check() { if ($("sample").hasChildNodes()) { alert(“子ノードがあります。”); } else { alert(“子ノードがありません。”); } }
nextSibling 構文] object.nextSibling 機能] オブジェクトの次のノードを参照する。 返値] ノードオブジェクトの参照 適用] 多くのノードオブジェクト 対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
兄弟ノードの参照
previousSibling 構文] object.previousSibling 機能] オブジェクトの前のノードを参照する。 返値] ノードオブジェクトの参照 適用] 多くのノードオブジェクト 対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
parentNodeプロパティ 構文] object.parentNode 機能] 親ノードを参照する。 適用] object 対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
親ノードの参照
createElementメソッド
書式] object.createElement(element) 説明] 引数で指定したエレメントを作成する。 引数] 要素(エレメント)の名前 戻値] 作成したオブジェクト。 適用] document 対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
要素ノードの作成
createTextNodeメソッド 書式] object.createTextNode(text) 機能] 指定されたテキストノードを作成する。 引数] 作成するテキスト 返値] TextNodeオブジェクト 適用] document 対応] [IE5~][Firefox1~][Safari1~][Opera8~][Netscape6~]
テキストノードの作成
appendChildメソッド 書式] object.appendChild(newChild) 機能] 指定したエレメントにオブジェクトを追加する。 引数] 追加する子ノードオブジェクト 返値] ノードオブジェクト 適用] 多くのタグ 対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
テキストノードの作成
function add() { var newNode = document.createElement("LI"); var text = document.createTextNode(“追加しました。”); newNode.appendChild(text); var parent = document.getElementById("sample"); parent.appendChild(newNode); }
属性ノードの作成
setAttributeメソッド
構文]object.setAttribute('attributeName', 'value', ['type‘] )
機能] オブジェクトに、引数で指定された属性を追加する。
引数] attributeNameはアトリビュート名を指定。 valueは値を指定。 typeは種類を指定。次のいずれか。 0(アトリビュート名の大文字小文字の区別をしない) 1(アトリビュート名の大文字小文字の区別をする)
返値] なし
insertBefore
書式] object.insertBefore(newNode, existingNode)
機能] オブジェクトの指定された既存のノードオブジェクトの前に 指定された新しいノードオブジェクトを挿入する。 引数] newNode: 新しいノードオブジェクトを指定。 existingNode: 既存のノードオブジェクトを指定。 戻値] ノードオブジェクト。
対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
既存ノードの前に新規ノードオブジェクトを挿入
insertAdjacentElement
書式] object.insertAdjacentElement(“type”, insObj) 機能] オブジェクトの指定された位置に隣接するエレメントオブジェクト を挿入する 引数] type:次のいずれかを指定しobjectノードに対する位置関係を指定する。 BeforeBegin 開始タグの前 AfterBegin 開始タグの後 BeforeEnd 終了タグの前 AfterEnd 終了タグの後 insObj: 追加する要素オブジェクトを指定。
返値] エレメントオブジェクトを返す。
隣接するエレメントにオブジェクトを挿入
replaceChild
書式] object.replaceChild(newNode, oldNode)
機能] オブジェクトの指定された子ノードオブジェクトを置き換える。
引数] newChildは新しい子供のノードオブジェクトを指定。 oldChildは古い子供のノードオブジェクトを指定。
返値] ノードオブジェクトを返す。
子ノードを置き換え
function change() { var node = document.getElementById("sample"); var oldNode = node.firstNode; var newNode = document.createTextNode(“新しいノード”); node.replaceChild(newNode, oldNode); }
テキストの挿入
insertData 構文] object.insertData(‘offset’, ‘text’)
機能] オブジェクト(object)に、第2引数で指定されたテキストを 挿入する。 引数] offsett:既存テキストのどの文字位置にテキストを挿入 するかを指定する。 text:挿入されるテキストリレラル。 ※既存テキストは英数字と漢字を区別しないで位置指定 できる。 適用] テキストノード、コメント 返値] なし。
removeNode 構文] object.removeNode(“value”) 機能] オブジェクトのノードオブジェクトを削除する。 引数] valueは値を指定。次のいずれか。 true(childNodesコレクションを含める) false(childNodesコレクションを含めない) 返値] ノードオブジェクトを返す。
[3] ノードの削除
ノードオブジェクトを削除
removeChild 構文] pnode.removeChild(cnode) 機能] オブジェクトの指定された子ノードオブジェクトを 削除する。 引数] pnode:親ノードオブジェクト。 cnode:子ノードオブジェクト。 返値] ノードオブジェクト。 対応] [IE5~][Firefox1~][Safari1~][Opera8~][Netscape6~]
子ノードオブジェクトを削除
removeAttribute 構文] object.removeAttribute('attributeName', ['type‘])
機能] オブジェクトの指定された属性値を削除する。 引数] attributeName:アトリビュート名を指定。 type:は種類を指定。次のいずれか。 0(アトリビュート名の大文字小文字の区別をしない) 1(アトリビュート名の大文字小文字の区別をする) 返値] true(削除)、false(非削除) 対応] [IE5~][Firefox1~][Safari1~][Opera8~][Netscape6~] 例] $(“id1”). removeAttribute(‘name', 0)
属性(attribute)を削除
イーザネット フレーム
IPデータグラム
TCPセグメント
12Byte 4B
24Byte
20Byte
HTTPヘッダ
ヘッダデータ量: 60Byte + HTTPプロトコルヘッダ
GET /docs/sw/http-header.html HTTP/1.1
Host: www.kanzaki.com
Accept: text/html, text/plain, text/sgml, */*;q=0.01
Accept-Encoding: gzip, compress Accept-Language: ja,en
If-Modified-Since: Sun, 2 Sep 2001 11:31:06 GMT
User-Agent: Lynx/2.8.2
HTTPプロトコル リクエストヘッダ例
HTTP/1.1 200 OK Date: Wed, 05 Sep 2001 06:06:19 GMT Server: Apache/1.3.12 Content-Location: http-header.html.ja Vary: negotiate,accept-language,accept-charset TCN: choice P3P: policyref="/w3c/p3p.xml",CP="NOI DSP COR ADM DEV OUR STP” Last-Modified: Wed, 05 Sep 2001 06:02:09 GMT Connection: close Content-Type: text/html; charset=shift_jis Content-Language: ja
HTTPプロトコル レスポンスヘッダ例
XMLHttpRequestでのデータ送受信オーバヘッド
ヘッダデータ量: 60Byte + HTTPプロトコルヘッダ
75
GET /docs/sw/http-header.html HTTP/1.1
Host: www.kanzaki.com
Accept: text/html, text/plain, text/sgml, */*;q=0.01
Accept-Encoding: gzip, compress Accept-Language: ja,en
If-Modified-Since: Sun, 2 Sep 2001 11:31:06 GMT
User-Agent: Lynx/2.8.2
HTTPプロトコル リクエストヘッダ例
HTTP/1.1 200 OK Date: Wed, 05 Sep 2001 06:06:19 GMT Server: Apache/1.3.12 Content-Location: http-header.html.ja Vary: negotiate,accept-language,accept-charset TCN: choice P3P: policyref="/w3c/p3p.xml",CP="NOI DSP COR ADM DEV OUR STP” Last-Modified: Wed, 05 Sep 2001 06:02:09 GMT Connection: close Content-Type: text/html; charset=shift_jis Content-Language: ja
HTTPプロトコル レスポンスヘッダ例
イーザネット フレーム
IPデータグラム
TCPセグメント
12Byte 4B
24Byte
20Byte
HTTPヘッダ
XMLHttpRequestでのデータ送受信オーバヘッド
Ajaxライブラリ
77 77 77
エフェクト系
コントロール系
サーバ リクエスト
ビジネス ロジック
言語機能強化
DWR
script.aculo.us Yahoo! UI Library
Plotr
ActiveWidgets Dojo
Yahoo! UI Library
DWR
Prototype.js MochiKit
開発者 ユーザ
[クライアント]
[サーバ]
Ajaxライブラリ
・UIツール
・リモーティングツール
78 78 78
エフェクト系
コントロール系
サーバ リクエスト
ビジネス ロジック
言語機能強化
DWR
script.aculo.us Yahoo UI Library
Plotr
ActiveWidgets Dojo
Yahoo UI Library
DWR
Prototype.js MochiKit
開発者 ユーザ
[クライアント]
[サーバ]
Ajaxライブラリ
[UIツール]
[リモーティングツール]
Web
GUI
Ajaxモデルでの処理の流れ
JavaScript (Ajaxエンジン)
⑤ 演算処理 ④ 表示制御
サーバ
① イベント処理
② サーバ通信
③ UI表示 XHTML+CSS ・XHTML 画面構成 ・CSS 表示制御
・テキストデータ ・XMLデータ
GET/POST
DOM
DOM API
言語機能
サーバリモーティング
Web
GUI
Ajaxモデルとライブラリ
JavaScript (Ajaxエンジン)
⑤ 演算処理 ④ 表示制御
サーバ
① イベント処理
② サーバ通信
③ UI表示 XHTML+CSS ・XHTML 画面構成 ・CSS 表示制御
・テキストデータ ・XMLデータ
GET/POST UI表現
言語機能拡張
サーバリモーティング
Ajaxian.com 2007 Survey Results http://ajaxian.com/
82
DWR(Direct WebRemoting)
82
http://getahead.ltd.uk/dwr/
DWR:Easy Ajax for Java
Ajaxアプリケーションを サーバサイドJavaで開発 するための JavaScript-Java連携用 フレームワーク
Apache License, Version 2.0 再配布要件 (1)LICENSEファイルを再配布物内の「どこか」に置く。 (2)再配布要件(自分の著作物も含む)は、適度に定めてよい。 付与要件 (1)LICENSEファイルを作る。(Apacheライセンス参照) (2)LICENSEファイルの中身に Copyright [yyyy] [著作権所有者の名前] をつける。(もちろん再配布物と一緒に入れる)
83 83
Ajaxクライアント サーバ
1.ネットワーク透過性 ローカルのJavaクラスのメソッド呼び出し感覚でリモートのメソッド呼出しが可能。 ※Remote Procedure Call vs Local Procedure Call
Java Beans
DWRの特徴
DWRでのシステム構成
DB
[ビュー] [コントローラ] [モデル]
DWR Client DWR Servlet Java Beans Ajax
[MVCモデル] M:Model ビジネスロジック V:View 表示機能 C:Controller 処理制御機能
:ユーザ記述
:DWRサポート
-制御機能(Controller)はシステム(DWR)に任せ、 開発者はビジネスロジック作成に専念できる。
dwr.xml [プレゼンテーション層] [ファンクショナル層] [データアクセス層] web.xml
[3層C/Sシステム] P: プレゼンテ-ション層 F: ファンクショナル層 D: データアクセス層
85 85 85
2.サーバ側Javaの記述はJava Beans(POJO)で行う
(1) DI(Dependency Injection) ・サーバ側JavaはJavaBeans(POJO)で記述し、サーバサイド単独でテストできる。
(2) DRY(Don’t Repeat Yourself) ・Java Beansでビジネスロジックを記述する事により、重複のないコード記述が可能。
(3) CoC(Convention over Configuration) ・アノテーションにより、dwr.xmlの設定内容をJavaBeansに記述することが可能。 [POJO(Plain Old Java Object)] JavaオブジェクトがEJB(特にEJB 3より前のEJB)のように特殊なものではなく、 ごく普通のJavaオブジェクトであることを強調した名称。 [DI(Dependency Injection)] 互いにの独立性が高いコンポーネントを、アプリケーションとして結合する為の技術 [DRY(Don’t Repeat Yourself)]
プログラムの重複を排除する考え方。 [CoC(Convention over Configuration)] 設定よりも規約
86 86 86
(2) DRY(Don’t Repeat Yourself)
DB
DWR Client
Java Beans (POJO)
[DRY=Don’t Repeat Yourself]同じプログラムコードを重複して記述しない。
・顧客情報表示 ・担当者表示 ・商品情報表示
顧客クラス
社員クラス
商品クラス
顧客関係 メソッド (crud)
社員関係 メソッド (crud)
商品関係 メソッド (crud)
DB
DB
DWR Servlet
コントローラ 機能
・機能単位でのクラス構成とメソッド定義 EX] 受注関係のCRUD処理をクラスに まとめる。 ・カスタマイズはオーバライドで行う。
87 87 87
3.リバースAjax - DWR 2.0から
サーバ側のJavaからクライアントのJavaScriptに非同期にデータ送信が可能 ⇒コールバック、サーバプッシュとも言われる ⇒チャットのような対話型のAjaxアプリケーションが記述しやすくなる。 DWRのリバースAjaxでは3つの方式をサポート Comet, Polling, Piggyback
88 88 88
DWRでの リバースAjax実装形式
1 Active Reverse Ajax [Full Streaming Mode] =Comet デフォルトのReverse Ajaxモードで、クライアントへのレスポンスは最も早い。
リクエスト受信後、ブラウザのコネクションがまだ生きているかを見るために、
60秒毎にコネエクションをクローズする。
[Early Closing Mode] =Comet リクエスト受信後、 60秒後にコネエクションをクローズする。
[Polling Mode] = Polling 60秒毎にポーリングを行って新しいデータがあるか確認する。最も多くのクライアントコネクションが可能。
2.Passive Reverse Ajax =piggyback サーバはクライアントへのキューイングしておき、次のリクエスト時に、同時にレスポンス送信する。サーバ側のコネクション保持も、クライアントからのポーリングもなく、この方式によるWebサーバへの追加の負荷は全くない。
89
4.UIとサーバ通信の分離
Ajaxエンジン
⑤演算処理 ④表示制御
サーバ
①イベント処理
②サーバ通信
③UI表示
Web GUI
XHTML+CSS
DWR 他コンポーネント
・通信機能 → DWR ・UI機能 → ActiveWidgets, Yahoo UI, Dojo etc =>分散アプリケーション、分散オブジェクトで一般的な形態 vs] GWT(Google Web Toolkit) は一体型
5.DWRサーブレットとユーザサーブレットの混在可
DB
[ビュー] [コントローラ] [モデル]
DWR Servlet Java Beans
dwr.xml
DWR Client Ajax
Ajax Client Java Beans
Servlet (ユーザ記述)
web.xml ユーザ記述Servletは ・web.xmlにDWR-Servletと併記可能 ただし、DWR-Servletの後に記述する。 ユーザ記述JavaBeansは ・dwr.xmlに定義しDWRのDEBUG機能 使用可能 ・JavaBeans(POJO)は全く同じ
リバースAjax ---- アクティブリバースAjax ---- フルストリーミングモード -- アーリイクロージングモード -- ポーリングモード ----パッシブリバースAjax
リバースAjaxの実装方式
(Piggyback)
(Comet)
(Comet)
(Polling)
92 92 92
・動的にページを生成するためのユーティリティメソッドを提供 コレクションクラスのオブジェクトをHTMLのテーブルやリストに展開するための メソッドが用意されている。JavaScriptに詳しくなくても、簡単にページを ダイナミックに生成できる。
・Java/JavaScript間のデータ変換で多くの型をサポート DWRでは、サーバのJavaオブジェクトとクライアントのJavaScriptオブジェクトの 間でデータ変換を行う。文字列や単純な型については何も指定しなくても 自動的に変換してくれる。また、次のような複雑な型であっても、簡単な記述 を追加することでDWRが自動的に変換してくれる。 オブジェクト例]Array 、Bean、Collection、DOM 、Enum
・Struts, JSF, Springなどのフレームワークとの統合 例えば、JSF(Java Server Faces)であれば、DWRからManagedBeansのオブジ ェクトを操作できる。
・多くのブラウザに対応 エラーハンドリング、タイムアウトハンドリング JavaScriptからサーバ側のJavaメソッドを呼び出すときに、エラーハンドラや タイムアウトの指定が簡単にできる。 ブラウザ例] Safari、Opera、Mozilla、Konqueror
6 その他
93 93 93
Tomcat5
サーブレット
コンテナ MySQL
FedoraCore5
プログラム作成 - DWR実行環境
APサーバ データベース
Tomcat 5.xx
J2EE 5.04
MySQL 4.1.11
IE 6.0.2800
FF 2.00.2
サンプル動作環境
WindowXP Pro V2
サーバ
クライアント IE6.0
ブラウザ IE 6.0
FF2.0
ブラウザ
サーブレット Java
Beans
DWR Version 2.0 RC 2
94 94 94
WARファイルでのDWRサンプル環境作成 1.WARファイル(dwr.war)のダウンロード http://getahead.org/dwr/download
95 95 95
2.dwr.warを$CATALINA_HOME/webapps に配置後Tomcat再起動 または、Tomcat Webアプリケーションマンージャからデプロイ
96 96 96
3.ブラウザで http://localhost:8080/dwr/ をアクセス ・初期画面の表示
DWRサンプルプログラム1 - Dynamic Address Entry オートコンプリート
98 98 98
DWRサンプルプログラム2 - reverse ajax 時計表示
99 99 99
DWRサンプルプログラム3 - reverse ajax チャット
100 100 100
初めてのDWR 従業員番号から氏名表示
DWRユーザプログラミング作成
$CATALINA_HOME
dwr2
WEB-INF
lib
book4
web.xml
aaa.htm
bbb.class
webapps
classes
erp
s5
lib
DWRディレクトリ構成
dwr.xml
hr
102 102 102
1. DWR JAR ファイルのダウンロードと配置 (1) http://getahead.org/dwr/download から dwr.jar ファイルをダウンロード。 (2) $CATALINA_HOME/webapps/[開発DIR]/WEB-INF/lib ディレクトリに配置 ※DWRディレクトリ(dwr.warでデプロイ)のlib内ファイルをすべてコピーで可
103 103 103
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd"> <web-app id="dwr"> <servlet> <servlet-name>dwr-invoker</servlet-name> <display-name>DWR Servlet</display-name> <servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class> <init-param> <param-name>debug</param-name> <param-value>true</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>dwr-invoker</servlet-name> <url-pattern>/dwr/*</url-pattern> </servlet-mapping> </web-app>
2. デプロイメントディスクリプタ(web.xml)の編集 WEB-INF/web.xml にdwr-invokerの行を追加. ※サーブレットの定義はdwr-invokerだけ。 ※DWRディレクトリのweb.xmlをコピーで可 web.xml
104 104 104
<?xml version="1.0" encoding="ISO-8859-1"?> <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd"> <web-app id="dwr"> <display-name>DWR (Direct Web Remoting)</display-name> <description>A demo of how to call Java on the server directly from Javascript on the client</description> <servlet> <servlet-name>dwr-invoker</servlet-name> <display-name>DWR Servlet</display-name> <description>Direct Web Remoter Servlet</description> <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class> <init-param> <param-name>debug</param-name> <param-value>true</param-value> </init-param> <init-param> <param-name>pollAndCometEnabled</param-name> <param-value>true</param-value> </init-param> <init-param> <param-name>allowGetForSafariButMakeForgeryEasier</param-name> <param-value>true</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dwr-invoker</servlet-name> <url-pattern>/dwr/*</url-pattern> </servlet-mapping> </web-app>
参考] web.xml(オリジナル)
105 105 105
package seminar1; import java.io.*; public class sem1Bean { String inPath = "/usr/local/tomcat5/apache-tomcat-5.5.20/webapps/dwr2/WEB-INF/ classes/seminar1/employee.txt"; public String getEmpName(String emp_no){ String empData = "", empNo = "", empName = ""; try { File inFile = new File(inPath); FileReader in = new FileReader(inFile); BufferedReader inBuffer = new BufferedReader(in); while ((empData = inBuffer.readLine()) != null) { empNo = empData.substring(0, 5); if(empNo.equals(emp_no)){ empName = empData.substring(5); break; } } inBuffer.close(); } catch (IOException e) {} return empName; } }
sem1Bean.java
3.サーバコード(JavaBeans:POJO)作成
106 106 106
4.WEB-INFディレクトリ下にdwr.xmを作成・配置
dwr.xml 定義
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" "http://www.getahead.ltd.uk/dwr/dwr10.dtd"> <dwr> <allow> <create creator="new" javascript="sem1Bean"> <param name="class" value="seminar1.sem1Bean"/> </create> </allow> </dwr>
5.tomcat再起動
creator=“new” :リクエストの際に、Javaオブジェクトの新しいインスタンス生成 ※scope属性 application アプリケーション全体で1つのインスタンス作成 session セッション毎にインスタンス生成 request リクエスト毎にインスタンスを生成 page ページ毎にインスタンスを生成
1.クラスファイルの指定
@RemoteProxy public class empBean { @RemoteMethod public String getEmpName(String emp_no){ : } }
POJOクラスをリモートアクセス可能にする為には, @RemoteProxy および @RemoteMethod
のアノテーション(annotation)を指定する。
※ クライアントアクセス名の変更 @RemoteProxy(name=”empInfo”)
参考] アノテーションの指定方法
108 108 108
package seminar1; import java.io.*; @RemoteProxy //リモートから使用するクラスであることを指定 public class sem1Bean { String inPath = "/usr/local/tomcat5/apache-tomcat-5.5.20/webapps/dwr2/WEB-INF/ classes/seminar1/employee.txt"; @RemoteMethod //リモートから使用するメソッドであることを指定 public String getEmpName(String emp_no){ String empData = "", empNo = "", empName = ""; try { File inFile = new File(inPath); FileReader in = new FileReader(inFile); BufferedReader inBuffer = new BufferedReader(in); while ((empData = inBuffer.readLine()) != null) { empNo = empData.substring(0, 5); if(empNo.equals(emp_no)){ empName = empData.substring(5); break; } } inBuffer.close(); } catch (IOException e) {} return empName; } }
アノテーション DWR記述の代替をビーンズコード内で行う。
<servlet> <servlet-name>dwr-invoker</servlet-name> <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class> <init-param> <param-name>classes</param-name> <param-value> erp.hr. empBean , erp.hr. hrBean </param-value> </init-param> <init-param> <param-name>debug</param-name> <param-value>true</param-value> </init-param> </servlet>
2.web.xmlにアノテーション適用JavaBeans指定
110 110 110
機能] 利用可能なすべてのJavaBeansをWebページ 上で確認できる。
6.デバックモードでJavaBeansの機能確認
<servlet> <servlet-name>dwr-invoker</servlet-name> <servlet-class>org.directwebremoting.servlet.DwrServlet</servlet-class> <init-param> <param-name>debug</param-name> <param-value>true</param-value> </init-param> </servlet>
1.web.xmlにdebug機能の使用を指定
111 111 111
2.http://(URL)/(Webアプリケーション名)/dwr/ にアクセスし、 利用可能なオブジェクトの一覧が表示される。
112 112 112
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <title>従業員番号から氏名表示</title> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../dwr/engine.js"></script> <script type="text/javascript" src="../dwr/util.js"></script> <script type="text/javascript" src="../dwr/interface/sem1Bean.js"></script> <script type="text/javascript"> //<![CDATA[ function reqEmpName(){ //var emp_no = idv("emp_no"); var emp_no = dwr.util.getValue(“emp_no”); //util.js sem1Bean.getEmpName(emp_no, respEmpName); //engine.js } function respEmpName(resp){ //id("emp_name").value = resp; dwr.util.setValue("emp_name") = resp; //util.js }
7.クライアントコード作成 dwrGetAsyn.htm 1/2
113 113 113
function initOnLoad(){ setListener($("emp_no“), "blur", reqEmpName); } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> <center> <h3>従業員番号から氏名表示</h3> <nobr> 従業員番号:<input type="text" size="10" id="emp_no"/> 従業員氏名:<input type="text" size="14" id="emp_name"/> </nobr> </center> </body> </html>
dwrGetAsyn.htm 2/2
114 114 114
<create>
<create creator=“生成方法” class=“JavaBeansクラスの完全修飾名” [javascript=“オブジェクト名”] [scope=“有効範囲”] [<auth method=“メソッド名” role=“ロール名” />] [<exclude method=“呼び出しを禁止するメソッド名” />] [<include method=“呼び出しを許可するメソッド名” />] </create>
<allow> DWRが生成・処理可能なクラス範囲を定義する
[参考]
creator属性(必須) - 以下のcreatorを指定. ※creatorにStruts、JSFのような外部フレームワークを指定すれば、 連携することが出きる。 通常はnewを指定。 [DWRで指定可能なcreator] : •new: Java の‘new’ オペレータを使用。 •none: オブジェクトを生成しない。 •scripted: BeanShell または BSFからのGroovyなどスクリプト言語を使用。 •spring: Spring Frameworkからのbeanアクセスを指定. •jsf: JSFからオブジェクトを使用。 •struts: strutsの FormBeansを使用 •pageflow: Beehive または Weblogic からの PageFlowアクセス •ejb3: EJB3のセッションbeansへのアクセス. ※ejb3は現在テスト段階
115 115 115
DWR関連jsファイル(ライブラリ&自動生成)
1./dwr/engine.js 必須のコアファイル XMLHttpRequestによる非同期通信を行う
2./dwr/util.js オプションのユーティリティファイル 例] DWRUtil.getValue()、DWRUtil.setValue()
3. /interface/sem1Bean.js sem1Bean.java固有のjsファイル DWRのサーブレット(DWRServlet)が動的に生成 demo1.Demoオブジェクトにアクセスするためのインターフェイスを提供
jsファイル名は dwr.xmlで指定 <create creator="new" javascript="sem1Bean">
メソッド 機能
$(id) 指定されたID値に対応する要素を所得する。
DWRUtil.getValue(id) 選択ボックスから値を所得する。
select要素を指定した場合は選択されているoptionの値が所得される。
DWRUtil.getValues(ids) 指定されたIDに対応する各要素のテキスト値を全て所得する。
DWRUtil.getValues(event, func) リターンキーを押下した場合の処理を定義する。
DWRUtil.setValue(id, value) IDで指定した要素をvalue指定の値に設定する。
DWRUtil.setValues(ids) {id1: テキスト1, id2:テキスト2 …} のように指定し、指定されたIDにテキスト値をセットする。
DWRUtil.removeAllOptions(id) IDで指定したselect要素、ul要素、ol要素のオプションをすべて削除する。
DWRUtil.addOptions(id, 配列) IDで指定したselect要素に配列内のテキストをoptionとして追加する。
DWRUtil.removeAllRows(id) IDで指定したテーブルからすべての行を削除する。
DWRUtil.addRows
(id,array,cellfuncs,[options])
IDで指定したテーブルに行を追加する。追加する行はarrayで指定された配列データをcellfuncsで指定された関数に従って追加する。
DWRUtil.getText(id) 指定されたID値に対応するテキストを所得する。
DWRUtil.selectRange(id,start,end) IDで指定された入力フィールドのstart ~ end文字目までをテキストを選択する。
DWRUtil.toDescriptiveString(id,opt) 指定された要素に関する情報をオプション(0~2)に従って表示する。
DWRUtil.useLoadingMessage() 通信中のメッセージを表示するように指定する。
117
[実習-1] ・DWRでの従業員から氏名表示を作成 ご自分のディレクトリで プログラム作成と動作確認を行って下さい。
118 118 118
リモートオブジェクトのオプション指定 オプション 概要 callback リモートコールが成功した場合の処理 errorHandoler リモートコール処理が失敗した場合の処理 ordered 要求された順番で結果を反映するか preHook リモートコール直前に行う処理 postHook リモートコール直後に行う処理 timmeout 要求のタイムアウト時間(ミリ秒) verb HTTPメソッド(GETまたはPOST) warninghandoler ブラウザによる警告が発生した場合の処理
<script type="text/javascript"> //<![CDATA[ function reqEmpName(){ empBean.getEmpName(idv("emp_no").toUpperCase(), { callback: function(resp){$("emp_name").value = resp;}, timeout: 5000, errHandler: function(msg){alert("Error:" + msg);} } ); } function initOnLoad(){ setListener($("emp_no"), "blur", reqEmpName); } setListener(window, "load", initOnLoad); //]]> </script>
リモートオブジェクトオプション指定例
120 120 120
参考:Javaチャット: DWRでのコールバック処理
121 121 121
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>DWR 軽量チャット バージョン 2.0</title> <link rel="stylesheet" type="text/css" href="../lib/style.css"/> <style type="text/css"> <!-- #chatlog {list-style-type: none;} --> </style> <script type='text/javascript' src='../lib/funcs.js'> </script> <script type='text/javascript' src='../dwr/engine.js'> </script> <script type='text/javascript' src='../dwr/interface/JavaChat.js'> </script> <script type='text/javascript' src='../dwr/util.js'> </script> <script type="text/javascript"> //<![CDATA[ function activate() { dwr.engine.setActiveReverseAjax(true); } function sendMsg() { var msg = $("name").value + ": " + $("text").value; JavaChat.addMessage(msg); }
JavaChat.htm 1/2
122 122 122
function listeners(){ addListener($("send"), "click", sendMsg, false); } addListener(window, "load", listeners, false); addListener(window, "load", activate, false); //]]> </script> </head> <body> <p class="t2">DWR:Javaチャット</p> <div class="t4"> ニックネーム: <input type="text" id="name" size="8"/> <input type="button" class="b2" id="send" value="送信"/> <br/> <textarea id="text" row="3" cols="50"></textarea> </div> <hr/> <ul id="chatlog"></ul> <div id="dwr-debug"></div> </body> </html>
JavaChat.htm 2/2
123 123 123
package cback; import java.util.Collection; import java.util.LinkedList; import org.directwebremoting.WebContext; import org.directwebremoting.WebContextFactory; import org.directwebremoting.proxy.dwr.Util; import org.directwebremoting.util.Logger; public class JavaChat{ public void addMessage(String text){ if (text != null && text.trim().length() > 0){ messages.addFirst(new Message(text)); while (messages.size() > 10){ messages.removeLast(); } } WebContext wctx = WebContextFactory.get(); String currentPage = wctx.getCurrentPage(); Util utilThis = new Util(wctx.getScriptSession()); utilThis.setValue("text", ""); Collection sessions = wctx.getScriptSessionsByPage(currentPage); Util utilAll = new Util(sessions); utilAll.removeAllOptions("chatlog"); utilAll.addOptions("chatlog", messages, "text"); } private LinkedList messages = new LinkedList(); protected static final Logger log = Logger.getLogger(JavaChat.class); }
JavaChat.java
124 124 124
package cback; import java.net.MalformedURLException; import java.net.URL; import org.directwebremoting.Security; public class Message{ public Message(String newtext){ text = newtext; if (text.length() > 256){ text = text.substring(0, 256); } text = Security.replaceXmlCharacters(text); try{ if (text.startsWith("http://")){ URL url = new URL(text); text = "<a href='#' onclick='window.open(¥"" + url.toExternalForm() + "¥", ¥"¥", ¥"resizable=yes, scrollbars=yes,status=yes¥");'>" + url.toExternalForm() + "</a>"; } } catch (MalformedURLException ex){ // Ignore - it's not a URL } } public long getId(){ return id; } public String getText(){ return text; } private long id = System.currentTimeMillis(); private String text; }
Message.java
Ajax
応用プログラム
126 126 126
DWRでCRUD処理 DWRでデータベース登録 社員マスタ登録
package erp.hr; import java.text.*; import java.util.Date; import java.sql.*; public class hrBean { StringBuffer respBuf = new StringBuffer(""); String resp = ""; String sql = ""; String server = "localhost"; String db = "ajax_ec"; String user = "mysql"; String pass = "callback"; String url = "jdbc:mysql://" + server + "/" + db + "?useUnicode=true&characterEncoding=UTF-8"; Connection con = null; public hrBean(){ try{ Class.forName("com.mysql.jdbc.Driver"); } catch (Exception e) { resp = "jdbc Driver load error"; } try{ con = DriverManager.getConnection(url, user, pass); } catch (Exception e) { resp = "jdbc Driver load error"; } }
hrBean.java 1/2 (1) サーバコード記述
public String addEmpHdr(String emp_no, String emp_name, String depart, String section){ Date now = new Date(); DateFormat df = new SimpleDateFormat("yyyy-MM-dd"); String ent_date = df.format(now); try{ sql = "insert into emp_hdr values( ?, ?, ?, ?, ?)"; PreparedStatement ps = con.prepareStatement(sql); ps.setString(1, emp_no); ps.setString(2, emp_name); ps.setString(3, depart); ps.setString(4, section); ps.setString(5, ent_date); ps.executeUpdate(); resp = "OK:登録成功 顧客ID:" + emp_no; }catch(SQLException e) { resp = "NO:登録不成功 SQエラー:" + e; } return resp; } }
hrBean.java addEmpHdr 2/2
<!DOCTYPE dwr PUBLIC "-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN" "http://www.getahead.ltd.uk/dwr/dwr10.dtd"> <dwr> <allow> <create creator="new" javascript="hrBean"> <param name="class" value="erp.hr.hrBean"/> </create> : </allow> </dwr>
(2) dwr.xml の記述
(3) DWRデバッガでサーバメソッド(addEmpHdr)の動作確認
131 131 131
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>社員登録</title> <link type="text/css" rel="stylesheet" href="../../lib/style.css"/> <script type="text/javascript" src="../../dwr/engine.js"></script> <script type="text/javascript" src="../../dwr/util.js"></script> <script type="text/javascript" src="../../dwr/interface/hrBean.js"></script> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA[ function addEmpHdr(){ var emp_no = idv("emp_no"); var emp_name = idv("emp_name"); var depart = idv("depart"); var section = + idv("section"); hrBean.addEmpHdr(emp_no, emp_name, depart, section, addStat); } function addStat(resp){ id("status").innerHTML = resp; }
dwrAddEmpHdr.htm 1/2 (4) クライアントコード記述
132 132 132
function initOnLoad(){ setListener(id("add"), "click", addEmpHdr); } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> <center> <div class="t3">社員マスタ管理</div> <table width="370" border="1"> <tbody> <tr><th colspan="2">社員マスタ登録</th></tr> <tr> <th width="110">社員番号</th> <td><input type="text" size="8" id="emp_no"/></td> </tr> <tr><th>社員氏名</th><td><input type="text" id="emp_name"/></td></tr> <tr><th>所属部</th><td><input type="text" size="32" id="depart"/></td></tr> <tr><th>所属課</th><td><input type="text" size="30" id="section"/></td></tr> <tr> <th><input type="button" id="add" value=" 登録 " /></th> <td id="status"> </td> </tr> </tbody> </table> </center> </body> </html>
dwrAddEmpHdr.htm 2/2
133 133 133
サンプル作成 2 DWRでデータベース参照 社員マスタ参照
public String revEmpHdr(String emp_no){ Connection con = null; try{ con = DriverManager.getConnection(url, user, pass); }catch (Exception e){ resp = "jdbc Driver load error"; } try{ String sql = "select * from emp_hdr where emp_no = ?"; PreparedStatement ps = con.prepareStatement(sql); ps.setString(1, emp_no); ResultSet rs = ps.executeQuery(); if(rs.first()) { respBuf.append("OK:参照ID:"+emp_no).append("<i>"); respBuf.append(rs.getString("emp_name")).append("<i>"); respBuf.append(rs.getString("depart")).append("<i>"); respBuf.append(rs.getString("section")).append("<i>"); respBuf.append(rs.getString("ent_date")).append("<i>"); } else { respBuf.append("NO:参照不成功").append("<i>"); } con.close(); }catch(SQLException e){} resp = respBuf.toString(); return resp; }
revEmpHdr
(1) サーバコード記述
(2) DWRデバッガでサーバメソッド(revEmpHdr)の動作確認
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>社員登録</title> <link type="text/css" rel="stylesheet" href="../../lib/style.css"/> <script type="text/javascript" src="../../dwr/engine.js"></script> <script type="text/javascript" src="../../dwr/util.js"></script> <script type="text/javascript" src="../../dwr/interface/hrBean.js"></script> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA[ function reqEmpHdr(){ hrBean.revEmpHdr(idv("emp_no"), respEmpHdr); } function respEmpHdr(resp){ var resp1 = resp.split("<i>"); id("status").innerHTML = resp1[0]; id("emp_name").innerHTML = resp1[1]; id("depart").innerHTML = resp1[2]; id("section").innerHTML = resp1[3]; id("ent_date").innerHTML = resp1[4]; }
dwrRevEmpHdr.htm 1/2
(3) クライアントコード記述
function initOnLoad(){ setListener(id("rev"), "click", reqEmpHdr); } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> <center> <div class="t3">社員マスタ管理</div> <table width="370" border="1"> <tbody> <tr><th colspan="2">社員マスタ参照</th></tr> <tr> <th width="110">社員番号</th> <td><input type="text" size="8" id="emp_no"/></td> </tr> <tr><th>社員氏名</th><td id="emp_name"> </td></tr> <tr><th>所属部</th><td id="depart"> </td></tr> <tr><th>所属課</th><td id="section"> </td></tr> <tr><th>更新日</th><td id="ent_date"> </td></tr> <tr> <th><input type="button" id="rev" value=" 参照 " /></th> <td id="status"> </td> </tr> </tbody> </table> </center> </body> </html>
dwrRevEmpHdr.htm 2/2
DOMイベントモデルでの応用
・ENTERキー押下で表示 ・ID入力と同時に表示
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>社員登録</title> <link type="text/css" rel="stylesheet" href="../../lib/style.css"/> <script type="text/javascript" src="../../dwr/engine.js"></script> <script type="text/javascript" src="../../dwr/util.js"></script> <script type="text/javascript" src="../../dwr/interface/hrBean.js"></script> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA[ function reqEmpHdr(e){ if(getkcode(e) == 13){ hrBean.revEmpHdr(idv("emp_no").toUpperCase(), respEmpHdr); } } function respEmpHdr(resp){ dispitems(resp, "emp_name"); } function initOnLoad(){ setListener(id("emp_no"), "keyup", reqEmpHdr); } setListener(window, "load", initOnLoad); //]]> </script>
dwrRevEmpHdrKey1.htm
if(idv("emp_no").length == 8){ hrBean.revEmpHdr(idv("emp_no").toUpperCase(), respEmpHdr); }
</head> <body> <center> <div class="t3">社員マスタ管理</div> <table width="370" border="1"> <tbody> <tr><th colspan="2">社員マスタ参照</th></tr> <tr> <th width="110">社員番号</th> <td><input type="text" size="14" id="emp_no"/></td> </tr> <tr><th>社員氏名</th><td id="emp_name"> </td></tr> <tr><th>所属部</th><td id="depart"> </td></tr> <tr><th>所属課</th><td id="section"> </td></tr> <tr><th>更新日</th><td id="ent_date"> </td></tr> <tr> <th> </th> <td id="status"> </td> </tr> </tbody> </table> </center> </body> </html>
オートコンプリート:社員マスタ参照
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>社員登録</title> <link type="text/css" rel="stylesheet" href="../../lib/style.css"/> <style type="text/css"> <!-- #emp_dat { position: relative; width:370px; height: 180px; } #auto { position: relative; margin-top: -132px; margin-left: 56px; padding: 0px; border-width: 1px; border-style: solid; border-color: #668; width: 186px; height: 130px; z-index: 1; overflow: auto; background-color: #fff; } --> </style>
dwrRevEmpHdrAuto1.htm
<script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../../lib/prototype.js"></script> <script type="text/javascript" src="../../dwr/engine.js"></script> <script type="text/javascript" src="../../dwr/util.js"></script> <script type="text/javascript" src="../../dwr/interface/hrBean.js"></script> <script type="text/javascript"> //<![CDATA[ var emp_no, autoRows, autoPos; function incEmpHdr(e){ var ckey = getkcode(e); if(ckey==38 || ckey==40){ autoIncLine(ckey); }else if(ckey==46){ $("emp_no").value = ""; $("emp_name").innerHTML = " "; $("depart").innerHTML = " "; $("section").innerHTML = " "; $("ent_date").innerHTML = " "; $("status").innerHTML = " "; $("emp_no").focus(); }else if(ckey==13){ emp_no = $("tr"+autoPos).firstChild.firstChild.nodeValue; $("auto").hide(); hrBean.revEmpHdr(emp_no, respEmpHdr); }else if($F("emp_no").length > 0){ hrBean.revEmpHdrAuto1($F("emp_no"), respEmpHdrAuto); }else{ $("auto").hide(); } }
function autoIncLine(ckey){ if(ckey==38){ if(autoPos > 0){ $("tr"+autoPos).style.backgroundColor = "#fff“ --autoPos; $("tr"+autoPos).style.backgroundColor = "#ff6“ } }else if(ckey==40){ if(autoPos < autoRows){ $("tr"+autoPos).style.backgroundColor = "#fff“ ++autoPos; $("tr"+autoPos).style.backgroundColor = "#ff6“ } } } function respEmpHdr(resp){ var recs = resp.split("<r>"); var items = recs[0].split("<i>") if(recs[0].length > 1){ $("emp_no").value = emp_no; $("emp_name").innerHTML = items[0]; $("depart").innerHTML = items[1]; $("section").innerHTML = items[2]; $("ent_date").innerHTML = items[3]; $("status").innerHTML = items[4]; }else{ $("status").innerHTML = items[0]; } }
function respEmpHdrAuto(resp){ var recs = resp.split("<r>"); if(recs.length > 1){ $("auto").show(); if($("auto").hasChildNodes()){ $("auto").firstChild.removeNode(true); } var table = document.createElement("table"); table.width = "167"; table.border = "1"; table.cellSpacing = "0"; table.cellPadding = "0"; autoRows = recs.length-1; autoPos = 0; for(var i = 0; i < autoRows; i++){ var items = recs[i].split("<i>"); var tr = table.insertRow(i); tr.id = "tr" + i; for(var j = 0; j < items.length; j++){ var td = tr.insertCell(j); j==0 ? td.width = "75" : td.width = "92"; td.appendChild(document.createTextNode(items[j])); } } $("auto").appendChild(table); }else{ $("status").innerHTML = recs[0]; } $("tr0").style.backgroundColor = "#ff8"; }
function initOnLoad(){ $("auto").hide(); setListener(id("emp_no"), "keyup", incEmpHdr); } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> <center> <div class="t3">社員マスタ管理</div> <table width="370" border="1"> <tbody> <tr><th colspan="2">社員マスタ参照</th></tr> <tr> <th width="110">社員番号</th> <td><input type="text" size="14" id="emp_no"/></td> </tr> <tr><th>社員氏名</th><td id="emp_name"> </td></tr> <tr><th>所属部</th><td id="depart"> </td></tr> <tr><th>所属課</th><td id="section"> </td></tr> <tr><th>更新日</th><td id="ent_date"> </td></tr> <tr> <th> </th> <td id="status"> </td> </tr> </tbody> </table> </center> </body> </html>
社員マスタ参照 チェックボックス
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>社員参照</title> <link type="text/css" rel="stylesheet" href="../../lib/style.css"/> <script type="text/javascript" src="../../dwr/engine.js"></script> <script type="text/javascript" src="../../dwr/util.js"></script> <script type="text/javascript" src="../../dwr/interface/hrBean.js"></script> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA[ function reqEmpAll(e){ hrBean.revEmpHdrLike1(getid(e), respEmpInfo); } function respEmpInfo(resp){ var recs = resp.split("<r>"); if(recs[0].substr(0,2) != "NO"){ if(!id("view").hasChildNodes()){ var table = document.createElement("table"); table.id = "out"; table.border = "1"; table.createTHead(); var tr = table.insertRow(0); for(var j = 0; j < 5; j++){ var td = tr.insertCell(j); td.align ="center";
switch(j){ case 0: td.width = "200"; var tl="所属部"; break; case 1: td.width = "80"; var tl="社員NO"; break; case 2: td.width = "100"; var tl="姓名"; break; case 3: td.width = "100"; var tl="所属課"; break; case 4: td.width = "100"; var tl="登録日"; break; } td.appendChild(document.createTextNode(tl)); } }else{ var table = id("out"); } for(var i = 0; i < recs.length-1; i++){ var items = recs[i].split("<i>"); var tr = table.insertRow(i+1); for(var j = 0; j < items.length; j++){ var td = tr.insertCell(j); td.align = "center"; td.appendChild(document.createTextNode(items[j])); td.align = "left"; } } if(!id("view").hasChildNodes()){ id("view").appendChild(table); }
}else{ id("view").innerHTML = recs[0]; } } function initOnLoad(){ setListener(id("sel"), "click", reqEmpAll); } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> <center> <h3>社員マスタ参照</h3> <div id="sel"> <input type=“checkbox” name=“ass” id=“GE”/>総務部 <input type=“checkbox” name=“ass” id=“AC”/>経理部 <input type=“checkbox” name=“ass” id=“PE”/>人事部 <input type=“checkbox” name=“ass” id=“SR”/>営業部 <input type=“checkbox” name=“ass” id=“SE”/>SE部 </div> <div id="view"></div> </center> </body> </html>
仕訳処理-データチェック
仕訳処理-マウス操作のないデータ入力
<?xml version="1.0" encoging="UTF-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja">
<head>
<title>クラス1登録</title>
<link rel="stylesheet" type="text/css" href="style.css" />
<script type="text/javascript" src="funcs.js"></script>
<script type="text/javascript">
//<![CDATA[
var httpObj = getHttpObject();
function setDebitAcct(e){
if(debit_code.value.length==4){
httpObj.open("GET", "setDebitAcct.php?acct_code="+debit_code.value);
httpObj.onreadystatechange = setDebitAcctExe;
httpObj.send(null);
}
}
function setDebitAcctExe(){
var debit_acct;
if(httpObj.readyState == 4){
if(httpObj.status == 200){
debit_acct = httpObj.responseText;
if(debit_acct.substring(0,2) == "NA"){
alert("借方勘定コード" + debit_code.value + "は存在しません");
}else{
document.getElementById("debit_acct").value = debit_acct;
}
}
}
}
addJournal.htm
1/3
function journalEntry(e){
var sendVal, code;
if(e.keyCode==13){
sendVal = "debit_code="+debit_code.value
+ "&debit_acct="+debit_acct.value
+ "&debit_amt="+debit_amt.value
+ "&credit_code="+credit_code.value
+ "&credit_acct="+credit_acct.value
+ "&credit_amt="+credit_amt.value
+ "&summary="+summary.value;
httpObj.open("POST", "addJournal.php", false);
httpObj.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
httpObj.send(sendVal);
resVal = httpObj.responseText;
document.getElementById("status").innerHTML = resVal;
}
}
function setListeners(e){
var eSource = document.getElementById("debit_code");
addListener(eSource, "keyup", setDebitAcct, false);
var eSource = document.getElementById("summary");
addListener(eSource, "keyup", journalEntry, false);
}
addListener(window, "load", setListeners, false);
//]]>
</script>
</head>
<body>
<center><span class="title2">Ajax e-Commerce</span></center><br />
<table width="300">
<tr bgcolor="#ccffcc">
<th align="center" class="title2">伝票番号</th>
<th align="center" class="title2">日付</th>
<th align="center" class="title2">会計区分</th>
</tr>
仕訳処理コード
addJournal.htm
2/3
<tr><td ><input type="text" size="10" id="check_no" /></td>
<td ><input type="text" size="10" /></td>
<td ><input type="text" size="25" /></td>
</tr>
</table>
<table width="735" border="0">
<tr bgcolor="#ccffcc">
<th>借方コード</th>
<th>勘定科目</th>
<th>借方金額</th>
<th>貸方コード</th>
<th>勘定科目</th>
<th>貸方金額</th>
<th>摘要</th>
</tr>
<tr><td><input id="debit_code" type="text" size="7" /></td>
<td><input id="debit_acct" type="text" size="15" /></td>
<td><input id="debit_amt" type="text" size="9" /></td>
<td><input id="credit_code" type="text" size="7" /></td>
<td><input id="credit_acct" type="text" size="15" /></td>
<td><input id="credit_amt" type="text" size="9" /></td>
<td><input id="summary" type="text" size="15" /></td>
</tr>
</table>
<table width="735">
<tr><td width="535" id="status"><td>
<th width="100" align="center" bgcolor="#ccffcc">借方合計</th>
<td width="100"><input type="text" size="12" /></td></tr>
<tr><td><td><th align="center" bgcolor="#ccffcc">貸方合計</th>
<td><input type="text" size="12" /></td></tr>
</table>
</body>
</html>
addJournal.htm
3/3
//<![CDATA[ function getAcct(e){ if(getid(e).split("_")[1] == "code"){ var dc = getid(e).split("_")[0]; var dc_code = $(dc + "_code").value; if(dc_code.length != 4) return; dc_acct = getsyn("getAcct.php?acct_code=" + dc_code); if(dc_acct.substring(0,2) == "NA"){ alert("勘定コード" + dc_code + "は存在しません"); }else{ $(dc + "_acct").value = dc_acct; $(dc + "_amt").focus(); } }else if(getid(e) == "remark" && getkcode(e) == 18){ $("status").innerHTML = postsyn("addJournal.php", Form.serialize("items")); } } //]]>
addJournal 短縮形
<?php
$acct_code = $_GET["acct_code"];
$server = "localhost";
$dbname = "ajax_ec";
$user = "mysql";
$passwd = "callback";
$sv = mysql_connect($server, $user, $passwd)
or die("Connection error1");
$db = mysql_select_db($dbname)
or die("updClass1S: Connection error2");
$sql = "select acct_name from account where acct_code='$acct_code'";
$rows = mysql_query($sql, $sv)
or die("setDebitAcct: Select error");
$row = mysql_fetch_array($rows, MYSQL_ASSOC);
if($row){
echo $row["acct_name"];
}else{
echo "NA";
}
?>
setDebitAcct.php
<?php
$acct_code = $_GET["acct_code"];
$server = "localhost";
$dbname = "ajax_ec";
$user = "mysql";
$passwd = "callback";
$sv = mysql_connect($server, $user, $passwd)
or die("Connection error1");
$db = mysql_select_db($dbname)
or die("updClass1S: Connection error2");
$sql = "select acct_name from account where acct_code='$acct_code'";
$rows = mysql_query($sql, $sv)
or die("setDebitAcct: Select error");
$row = mysql_fetch_array($rows, MYSQL_ASSOC);
if($row){
echo $row["acct_name"];
}else{
echo "NA";
}
?>
addJournal.php
create table account ( acct_code varchar(8) not null primary key, acct_name varchar(20), remark varchar(30)
)
create table journal ( check_no varchar(8) not null, debit_code varchar(8) not null, debit_acct varchar(16), debit_amt int, credit_code varchar(8) not null, credit_acct varchar(16), credit_amt int, remark varchar(30) )
勘定テーブル
勘定テーブル
ECサイトでの商品表示
-商品表示:購入目的商品を効率よく探し出す -金額表示:現在の購入金額を自動表示する
クラス1項目
クラス2項目
クラス3項目
商品マスタ
ECサイトでの商品表示-操作手順
商品マスタ 登録/参照/更新/削除
DWRを使用できない例 – 再帰処理でのUI表示 ⇒DEBUG機能は使用可能
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>部品構成表示</title> <style type="text/css"> <!-- #upain{ position:absolute; top:25px; left:10px; width:700; height:125px; } #lpain{ position:absolute; top:125px; left:10px; width:700; height:140px; } --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA[ var xhrObj = getXhrObj(); var finalItems, finalItem;
var finalFlags = new Array();
/bomTree1.htm
function initOnLoad(){ var tagNode, docNode; xhrObj.open("get", "../../mrpsvlt?mode=getfinal", true); xhrObj.setRequestHeader("If-Modified-Since", "01 Jan 2000 00:00:00 GMT"); xhrObj.send(null); xhrObj.onreadystatechange = function(){ if(xhrObj.readyState == 4){ if(xhrObj.status == 200){ finalItems = xhrObj.responseText.split("<i>"); for(var i in finalItems){ docNode = document.createTextNode('[0] '+finalItems[i]); tagNode = document.createElement("div"); tagNode.setAttribute("id", finalItems[i]); tagNode.appendChild(docNode); id("tree").appendChild(tagNode); } for(var i=0; i < finalItems.length; i++){ finalFlags[i] = "N"; } } } } setListener(id("tree"), "click", getChild); setListener(id("tree"), "mouseover", getItemMas); }
function getChild(e, level, p_item){ var i, j, k, index, pad = ''; var childItems, childItem, tagNode, docNode; var eid = getid(e); if(!level){ level = 1; p_item = eid; if(eid.substr(0, 1) != 'A'){ return(0); }else{ for(j in finalItems){ if(finalItems[j] == eid){ if(finalFlags[j] == 'Y'){ return(0); }else{ finalFlags[j] = 'Y'; break; } } } } }else{ level++; } for(k=0; k<level; k++){ pad+='------'; }
index = '['+level+'] ' + pad; xhrObj.open("get", "../../mrpsvlt?mode=getchild&p_item="+p_item, false); xhrObj.setRequestHeader("If-Modified-Since", "01 Jan 1970 00:00:00 GMT"); xhrObj.send(null); childItems = xhrObj.responseText.split("<r>"); for(i in childItems){ childItem = childItems[i].split("<i>"); tagNode = document.createElement("div"); tagNode.setAttribute("id", childItem[1]); docNode = document.createTextNode(index+childItem[1]+" 在庫数量:"+childItem[3]); tagNode.appendChild(docNode); id(p_item).appendChild(tagNode); if(childItem[2]=="y"){ p_item = childItem[1]; getChild(e, level, p_item); } } }
function getItemMas(e){ var item_no = getid(e); if(item_no != "tree" && item_no.charAt(0) != "A"){ xhrObj.open("get", "../../mrpsvlt?mode=getiteminfo&item_no=" + item_no); xhrObj.setRequestHeader("If-Modified-Since", "01 Jan 1970 00:00:00 GMT"); xhrObj.send(null); xhrObj.onreadystatechange = function(){ if(xhrObj.readyState == 4){ if(xhrObj.status == 200){ var get = xhrObj.responseText.split("<i>"); var out = "<table width='500' border='1'><tr>" + "<td>部品番号</td><td>部品名</td><td>ベンダNO</td><td>ベンダ名</td></tr><tr>" + "<td>"+item_no+"</td><td>"+get[0]+"</td><td>"+get[2]+"</td><td>"+get[3]+"</td>" + "</tr></table>"; id("item").innerHTML = out; } } } } } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> <h2>Ajax-ERP 部品構成表示</h2> <table id="upain"><tr><td>部品情報</td><td id="item"></td></tr></table> <table id="lpain"><hr/><tr><td id="tree"></td></tr></table> </body> </html>
169
部品構成にソート機能追加、マウスドラッグで構成配置変更
170 170 170
script.aculo.us (スクリプタキュラス)
http://script.aculo.us/ Web画面にエフェクト効果を 与えるJavaScriptライブラリ ・Ajaxコンロトロール ・アニメーション ・ドラッグ&ドロップ ・DOMユーティリティ ・ユニットテスト ・MIT License
171 171 171
Scaleサンプル
172 172 172
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Scale</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Scale(){ new Effect.Scale("area", 500); //$("area").visualEffect("Scale"); } function listeners(){ addListener($("exe"), "click", Scale, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">Scaleサンプル</h2> <img id="area" src="fuji.jpg" width="150" height="110"/> </body> </html>
scale.htm
173 173 173
Droppableサンプル
174 174 174
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>script.aculo.us ドラッグ&ドロップ</title> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <style type="text/css"> <!-- #box1 { position:absolute; top:50px; left:10px; z-index:2;width:150px;height:60px;background:#ccf;} #box2 { position:absolute; top:50px; left:170px; z-index:1;width:150px;height:60px;background:#fcc;} #dropBox {position:absolute; top: 200px; left:10px; z-index:0;width:310px;height:180px;background:#cfc;} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../../lib/scriptaculous.js"></script> <script type="text/javascript" src="../../lib/unittest.js"></script>
droppable.htm 1/2
175 175 175
<script type="text/javascript" charset="utf-8"> //<![CDATA[ //var dragObj; function func1(){ new Draggable("box1", { revert:true } ); new Draggable("box2", { revert:true } ); Droppables.add("dropBox", { onDrop: function(element, droppableElement){ $(droppableElement).innerHTML += "<br/>" + element.id + "がドロップされました"; }, accept:"out" }); } addListener(self, "load", func1, false); //]]> </script> </head> <body> <h2>script.aculo.us ドロップエリア設定</h2> <div id="box1" class="out">box1:<br/>ドロップできます</div> <div id="box2">box2:<br/>ドロップできません</div> <div id="dropBox">ドロップゾーン:</div> </body> </html>
droppable.htm 1/2
176 176 176
Sortable エレメントのソート処理を指定する 書式
Sortable.create(element, option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 tag : ソート対象タグ名 only : 指定されたスタイルシートが適用された項目のみソート対象 overlap : 方向(horizontalまたはvertical) constraint : 移動方向制限(horizontal : 水平のみ、vertical : 垂直のみ) containment : handle : ハンドル(エレメント名を指定) hoverclass : 重なった場合のスタイルシートクラス名 ghosting : ドラッグ前のエレメントを表示したままにするかどうか (true : する、false : しない) dropOnEmpty : scroll : scrollSensitivity : scrollSpeed : スクロール速度 tree : 子ノードもソート対象にするか(true : する、false : しない) treeTag : ソート対象を内包するコンテナのタグ名 onChange : ソートされ順序が変更された時の処理 onUpdate : ソートされ順序が変更された後の処理
ソート(Sortable)
177 177 177
Sortableサンプル-1
Sortableサンプル-1 :FireBugでのDOMツリー変化確認
179 179 179
<style type="text/css" media="screen"> <!-- #list { padding: 2px; background:red;} #list li { background: #ffb; margin:2px; padding: 2px; } .area {width:350px;height:300px;overflow:scroll; position:relative;" id="scroll-container"; } --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js"></script> <script type="text/javascript" src="../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function sorta(){ Position.includeScrollOffsets = true; Sortable.create('list',{scroll:'scroll-container'}); } addListener(self, "load", sorta, false); //]]> </script> </head> <body> <h2>script.aculo.us ソータブル</h2> <div class="area"> <ul id="list"> <li>北海道</li><li>青森</li><li>秋田</li><li>岩手</li><li>山形</li> <li>宮城</li><li>福島</li><li>栃木</li><li>群馬</li><li>茨城</li> <li>千葉</li><li>埼玉</li><li>東京</li><li>神奈川</li><li>山梨</li> </ul> </div> </body> </html>
sort1.htm
リクエスト待受 リクエスト送信
レスポンス待受 レスポンス送信
条件成就?
Y
N
クライアント サーバ
クライアント型処理
サーバ型処理
Ajaxでのコールバック処理
Ajax コールバックサンプル-1 (タイマープルでのコールバック)
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>Ajax Callback Sample</title> <script type="text/javascript" src="../funcs.js"></script> <script type="text/javascript" src="cback.js"></script> </head> <body> <h2>Ajax コールバックサンプル</h2> この画面は自動的に更新されます。 <input type="button" value="スタート" id="start" /> <p>このページの更新は <span id="time">3</span> 秒毎に行われます。</p> <table id="callbackout" align="left" border="1" width="320"> <tbody> <tr><th align="center">日本の歴史</th></tr> </tbody> </table> </body> </html>
cback.htm
//<![CDATA var httpObj = getHttpObject(); function initCallBack() { httpObj.open("get", "../cback?stat=init"); httpObj.onreadystatechange = initCallBackExe; httpObj.send(null); } function initCallBackExe() { if (httpObj.readyState == 4) { if (httpObj.status == 200) { setTimeout("startCallBack()", 3000); waitTime(); } } } function startCallBack() { httpObj.open("get", "../cback?stat=exe"); httpObj.onreadystatechange = startCallBackExe; httpObj.send(null); }
cback.js
function startCallBackExe() { if (httpObj.readyState == 4) { if (httpObj.status == 200) { var get = httpObj.responseText; if (get.substring(0,3) != "end") { var new_row = create_tr(get); var table = document.getElementById("callbackout"); var table_body = table.getElementsByTagName("tbody").item(0); var first_row = table_body.getElementsByTagName("tr").item(1); table_body.insertBefore(new_row, first_row); setTimeout("startCallBack()", 3000); waitTime(); } } } }
function waitTime(){ var time_span = document.getElementById("time"); var time_val = time_span.innerHTML; var intval = parseInt(time_val); var new_intval = intval - 1; if (new_intval > -1) { setTimeout("waitTime()", 1000); time_span.innerHTML = new_intval; } else { time_span.innerHTML = 3; } } function create_tr(get) { var tr = document.createElement("tr"); var td = document.createElement("td"); var td_data = document.createTextNode(get); td.appendChild(td_data); tr.appendChild(td); return tr; } function setListeners() { var eSrc = document.getElementById("start"); addListener(eSrc, "click", initCallBack, false); } addListener(window, "load", setListeners, false); //]]>
package callback; import java.io.*; import javax.servlet.*; import javax.servlet.http.*; public class cback extends HttpServlet { private int cnt = 1; protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException { req.setCharacterEncoding("utf-8"); res.setContentType("text/html; charset=utf-8"); res.setHeader("Cache-Control", "no-cache"); PrintWriter out; out = res.getWriter(); String stat = req.getParameter("stat"); String info = "";
cback.java
if (stat.equals("init")) { cnt = 1; } else { switch (cnt) { case 1: info = "大和国家の成立と発展"; break; case 2: info = "荘園の発展と貴族社会"; break; case 3: info = "公家の没落と武家政権の成立"; break; case 4: info = "荘園制の解体と権力の分散"; break; case 5: info = "戦国大名と織豊政権"; break; case 6: info = "幕藩体制の成立と封建文化の展開"; break; case 7: info = "封建体制の動揺"; break; case 8: info = "幕藩体制の崩壊と明治国家の成立"; break; case 9: info = "資本主義の発達と国際政局への登場"; break; case 10: info = "第一次世界大戦と大正デモクラシー"; break; case 11: info = "第二次世界大戦と帝国主義の崩壊"; break; case 12: info = "敗戦による改革とその変容"; break; case 13: info = "end"; break; } cnt++; } out.println(info); out.close(); } }
Ajax コールバックサンプル-1 (サーバ条件マッチでのコールバック)
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>Ajax Callback Sample</title> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="cbacks.js"></script> </head> <body> <h2>Ajax コールバック(777マッチ)</h2> マッチナンバー <input type="text" value="777" id="number" size="6"/> <input type="button" value="スタート" id="start"/> <br/><br/> <table id="cbout" align="left" border="1" width="320"> <tbody><tr><th align="center">マッチ</th></tr></tbody> </table> </body> </html>
cbacks.htm
cbacks.htm
//<![CDATA var xhrObj = getXhrObj(); function cbackReq() { var number = id("number").value; xhrObj.open("get", "../cbacks1?number="+number); xhrObj.onreadystatechange = cbackResp; xhrObj.send(null); } function cbackResp() { if (xhrObj.readyState == 4) { if (xhrObj.status == 200) { var resp = xhrObj.responseText; var new_row = create_tr(resp); var table = document.getElementById("cbout"); var table_body = table.getElementsByTagName("tbody").item(0); var first_row = table_body.getElementsByTagName("tr").item(1); table_body.insertBefore(new_row, first_row); cbackReq(); } } }
cbacks.js
function create_tr(get) { var tr = document.createElement("tr"); var td = document.createElement("td"); var td_data = document.createTextNode(get); td.appendChild(td_data); tr.appendChild(td); return tr; } function initOnLoad() { setListener(id("start"), "click", cbackReq); } setListener(window, "load", initOnLoad); //]]>
package callback; import java.io.*; import java.text.*; import java.util.Date; import javax.servlet.*; import javax.servlet.http.*; public class cbacks1 extends HttpServlet { private int rnd1, rnd2; protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException { req.setCharacterEncoding("utf-8"); res.setContentType("text/html; charset=utf-8"); res.setHeader("Cache-Control", "no-cache"); PrintWriter out; out = res.getWriter(); String match_date = ""; int number = Integer.parseInt(req.getParameter("number")); DateFormat df = new SimpleDateFormat("yyyy-MM-dd-kk-mm-ss");
cbacks1.java
for(;;) { rnd1 = (int)(Math.random() * 10000); rnd2 = (int)(Math.random() * 10000); if (rnd1 == number && rnd2 == number){ Date now = new Date(); match_date = df.format(now); out.println("マッチナンバー > "+rnd1+" :"+match_date); out.flush(); break; }else{ continue; } } out.close(); } }
“777マッチ”でのコールバックと自動グラフ表示
777コールバック表示:使用される要素技術とライブラリ
[要素技術とライブラリ] ①イベント処理 -click +funcs.js ②サーバ通信 -繰返し継続での非同期通信 (GET/非同期) +funcs.js ③+④+⑤表示制御 -DOMノード操作 -連想配列処理(グラフ表示用) +plotr(グラフ) +Yahoo! UI Library(ドラッグ&ドロップ)
196 196
http://www.solutoire.com/plotr Ajaxモデルでのグラフ作成
Plotr ・グラフ作成 -棒グラフ -折れ線グラフ -円グラフ ・ブラウザサポート Firefox 1.5+ Safari 2.0+ Opera 9.0+ IE6+ (emulated) ・BSD LIcense
BSD License ・無保証であることの明記と著作権表示だけを再頒布の条件とする。 ・著作権表示を行えば、BSDライセンスのソースコードを他のプログラム に組み込み、組み込み後のソースコードを非公開にできる。
197 197
Plotrインストール手順
http://www.solutoire.com/plotr からダウンロード・解凍後、下記css、jsァイル指定
※ prototype.js 1.5 が必要
<script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/plotr/plotr.js"></script> <script type="text/javascript" src="../lib/plotr/excanvas.js"></script>
198 198
棒グラフ表示例-1
199 199
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="content-type" content="text/html;charset=utf-8"> <title>DrawPie1</title> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/plotr/plotr.js"></script> <script type="text/javascript" src="../lib/plotr/excanvas.js"></script> <script type="text/javascript"> //<![CDATA[ function drawGraph(){ //コード記述 } function setListeners(){ addListener($("draw"), "click", drawGraph, false); } addListener(self, "load", setListeners, false); //]]> </script> </head> <body> <h2>Draw Pie1 <input type="button" id="draw" value="グラフ表示" /></h2> <div><canvas id="graph" height="300" width="600"></canvas></div> </body> </html>
棒グラフ表示例ー1 html
1.canvasタグで描画領域を設定し ID名を指定。
200 200
function drawGraph(){ var dataset = { "y2006Q3": [[0, 1], [1, 1], [2, 1.2], [3, 1.5]], "y2007Q1": [[0, 0.5], [1, 0.89], [2, 2.15], [3, 4]], "y2007Q2": [[0, 0.2], [1, 0.79], [2, 3.95], [3, 3.2]], "y2007Q3": [[0, 1.2], [1, 2.79], [2, 4.95], [3, 5.2]] }; var options = { padding: {left: 80, right: 0, top: 10, bottom: 10}, backgroundColor: "#dbdbdb", colorScheme: "#009", xTicks: [ {v:0, label:"商用Unix"}, {v:1, label:"FreeBSD"}, {v:2, label:"Linux"}, {v:3, label:"Windows"} ] }; var bar = new Plotr.BarChart("graph", options); bar.addDataset(dataset); bar.render(); }
棒グラフ表示例-1 javascript
2.canvasタグのID名を Plotr.BarChart()の最初のパラメータとして指定 3.2番目のパラメータはグラフを描画するオプション を指定。
201 201
棒グラフ表示例-2
202 202
function drawGraph(){ var dataset = { "py2007Q2": [[0, 1], [1, 1], [2, 1.2], [3, 1.5]], "py2007Q3": [[0, 0.5], [1, 0.89], [2, 2.15], [3, 4]] }; var options = { padding: {left: 80, right: 0, top: 10, bottom: 10}, backgroundColor: "#ff8", colorScheme: "#500", barOrientation : "horizontal", xTicks: [ {v:0, label:"商用Unix"}, {v:1, label:"FreeBSD"}, {v:2, label:"Linux"}, {v:3, label:"Windows"} ] }; var bar = new Plotr.BarChart("graph", options); bar.addDataset(dataset); bar.render(); }
棒グラフ表示例-2 javascript
203 203
棒グラフ表示例-3 (枠線の指定)
204 204
function drawGraph(){ var dataset = { "y2006Q3": [[0, 1], [1, 1], [2, 1.2], [3, 1.5]], "y2007Q1": [[0, 0.5], [1, 0.89], [2, 2.15], [3, 4]], "y2007Q2": [[0, 0.2], [1, 0.79], [2, 3.95], [3, 3.2]], "y2007Q3": [[0, 1.2], [1, 2.79], [2, 4.95], [3, 5.2]] }; var options = { padding: {left: 80, right: 0, top: 10, bottom: 10}, backgroundColor: "#ececec", colorScheme: "#00a", strokeWidth : 3, strokeColor:"Red", xTicks: [ {v:0, label:"商用Unix"}, {v:1, label:"FreeBSD"}, {v:2, label:"Linux"}, {v:3, label:"Windows"} ] }; var bar = new Plotr.BarChart("graph", options); bar.addDataset(dataset); bar.render(); }
棒グラフ表示例-3 javascript
折れ線グラフの描画方法 ・canvasタグで描画領域を設定。 ・canvasタグにID名を指定し、 このID名をPlotr.LineChart()の最初のパラメータとして指定 ・2番目のパラメータはグラフを描画するオプションを指定。
206 206
折れ線グラフ表示例-1
207 207
function drawGraph(){ var dataset = { "y2007Q1": [[0, 5.5], [1, 7.89], [2, 8.15], [3, 9.8]], "y2006Q4": [[0, 1], [1, 2], [2, 3.2], [3, 4.5]], "y2006Q3": [[0, 0.5], [1, 1.6], [2, 1.2], [3, 1.5]] }; var options = { padding: {left: 50, right: 0, top: 10, bottom: 10}, backgroundColor: "#dbdbdb", colorScheme: "#009", xTicks: [ {v:0, label:"FY2007:1Q"}, {v:1, label:"FY2007:2Q"}, {v:2, label:"FY2007:3Q"}, {v:3, label:"FY2007:4Q"} ] }; var gLine = new Plotr.LineChart("graph", options); gLine.addDataset(dataset); gLine.render(); }
折線グラフ表示例-1 javascript
208 208
折れ線グラフ表示例-2
209 209
function drawGraph(){ var dataset = { "y2007Q1": [[0, 5.5], [1, 7.89], [2, 8.15], [3, 9.8]], "y2006Q4": [[0, 1], [1, 2], [2, 3.2], [3, 4.5]], "y2006Q3": [[0, 0.5], [1, 1.6], [2, 1.2], [3, 1.5]] }; var options = { padding: {left: 50, right: 0, top: 10, bottom: 10}, backgroundColor: "#dbdbdb", colorScheme: "#550000", shouldFill: false, xTicks: [ {v:0, label:"FY2007:1Q"}, {v:1, label:"FY2007:2Q"}, {v:2, label:"FY2007:3Q"}, {v:3, label:"FY2007:4Q"} ] }; var gLine = new Plotr.LineChart("graph", options); gLine.addDataset(dataset); gLine.render(); }
折線グラフ表示例-1 javascript
円グラフの描画方法 ・canvasタグで描画領域を設定。 ・canvasタグにID名を指定し、 このID名をPlotr.PieChart()の最初のパラメータとして指定 ・2番目のパラメータはグラフを描画するオプションを指定。
211 211
円グラフ表示例
212 212
function drawGraph(){ var dataset = { "share": [[0, 8], [1, 18], [2, 28], [3, 46]] }; var options = { padding: {left: 50, right: 0, top: 10, bottom: 10}, backgroundColor: "#dbdbdb", colorScheme: "#00a", xTicks: [ {v:0, label:"商用Unix"}, {v:1, label:"FreeBSD"}, {v:2, label:"Linux"}, {v:3, label:"Windows"} ] }; var pie = new Plotr.PieChart("graph", options); pie.addDataset(dataset); pie.render(); }
円グラフ表示例 javascript
213
[実習-2] 棒グラフをご自分のディレクトリで 動作確認してください。
214 214 214
DB
web.xml
Web
GUI
Web
GUI
コンテキスト・オブジェクト
コールバック
レスポンス コールバック
リクエスト 受注登録
受注DB
パラメータ情報
登録 確認
コンテキスト・オブジェクトを使用したコールバック処理 受注情報の登録とコールバックの別画面表示
Ajaxクライアント
Javaサーブレット Javaサーブレット
Ajaxクライアント
215 215 215
非同期処理でのリッチクライアント - 受注情報登録画面
受注情報登録でのAjax適用
←顧客IDまたはTEL
入力と同時に顧客情報
を自動表示
←カレンダ日付けクリック
で受注関連年月日情報
の入力と変更
←商品IDと数量入力で
-商品名自動表示
-小計と合計額自動表示
受注情報登録と別画面へのコールバック表示 -表示受注一覧からボリュームオーダへのドラッグ&ドロップ
受注情報登録:使用される要素技術とライブラリ
[要素技術とライブラリ] ①イベント処理 -DOMイベントモデル イベントオブジェクト、テキスト入力長 +funcs.js
②サーバ通信⑤演算処理 -非同期通信利用のコールバック (GET/非同期) +funcs.js
③+④表示制御 -DOMノード操作 -CSSスタイル指定 +Yahoo! UI Library(日本語カレンダ表示、ドラッグ&ドロップ)
+script.aculo.us(ドラッグ&ドロップ) ※サーバサイド +コンテキストオブジェクト(サーブレット)
・Programmable Web Google Maps API の追加
・マルチメディア表示
DB
wiki
blog
sns
Yahoo!
Amazon
ロングテイル 集合知 ユーザ参加 貢献者としてのユーザ
SOAP
REST HTTP
+
XML
DB
DB
ユーザ参加
貢献者としてのユーザ
Folksonomy
ユーザーの手による情報の自由な整理
集合知
根本的な信頼
Ajax
マルチデバイス
RSS ATOM
Webサービス ・プログラマブルWeb ・マッシュアップ
プラットホームとしてのWeb
リッチなユーザ体験
XHR
マッシュアップ
Ajax API
公開
DB
社内システム
適用業務
マッシュアップ
マッシュアップ構成とライブラリの粒度
小粒度:言語機能 ・Prototype.js
中度:コントロール ・ActiveWidgets ・Script.aculo.us
大粒度:コンポーネント ・Yahoo!UIカレンダ ・Plotrグラフ作成
サイト内 外部インターネット (プログラマブルWeb)
ダウン ロード
SOAP/REST XHR
REST
[Webサーバ] [Webクライアント]
Ajax
XHR
Web ブラウザ
サーバ プログラム
サーバ プログラム
・Google SOAP Search API
・Google AJAX Search API ・Google Maps API
アプリケーション プログラム
ライブラリ
Type1
Type2
Type3
マッシュアップ構成とライブラリの粒度
小粒度:言語機能 ・Prototype.js
中度:コントロール ・ActiveWidgets ・Script.aculo.us
大粒度:コンポーネント ・Yahoo!UIカレンダ ・Plotrグラフ作成
サイト内 外部インターネット (プログラマブルWeb)
ダウン ロード
SOAP/REST XHR
REST
[Webサーバ] [Webクライアント]
Ajax
XHR
Web ブラウザ
サーバ プログラム
サーバ プログラム
・Google SOAP Search API
・Google AJAX Search API ・Google Maps API
アプリケーション プログラム
ライブラリ
Type1
Type2
Type3
IMG
Google Maps API
Google Mapsの使い方
(1) Googleアカウントを所得 https://www.google.com/accounts/ ManageAccount
(2)Google Maps APIキーの所得 http://www.google.com/apis/maps/
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <head><title>Google Maps</title> <script src="http://maps.google.com/maps?file=api&v=2&key=ABQIAAAAAO-r1bqRz2fZr-Qmjsew WxRgE_H9GM6zkZRwNii93jtvjOSYqRTUvjXBD0wChGoBh2xb30zNzkqZmA" type="text/javascript"> </script> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA[ function initOnLoad(){ var map = new GMap2(id("map")); map.setCenter(new GLatLng(35.6815617, 139.7672091), 15); map.addControl(new GLargeMapControl()); map.addControl(new GMapTypeControl()); } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> コントロールとボタンを追加する <div id="map" style="width: 500px; height: 370px"></div> </body> </html>
gmaps5.htm
マーカクリックで画像付き 吹き出しを表示する
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <head><title>Google Maps</title> <script src="http://maps.google.com/maps?file=api&v=2&key=ABQIAAAAAO- r1bqRz2fZr-QmjsewWxRgE_H9GM6zkZRwNii93jtvjOSYqRTUvjXBD0wChGoBh2 xb30zNzkqZmA" type="text/javascript"></script> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA[ function initOnLoad(){ img = new Image(); img.src = './tokyo.jpg'; var tags = '<div style="width:260px"><img src="'+img.src+'" width="240"/>‘ + "<br/><b>[東京駅]</b>東京都、中央区<br/>" + "ここへ到着、ここから出発<br/>付近を検索、マイマップに保存<br/>"; var map = new GMap2(id("map")); map.addControl(new GLargeMapControl()); map.setCenter(new GLatLng(35.6815617, 139.7672091), 15);
var lon = 139.7672091; //東京駅の経度 var lat = 35.6808617; //東京駅の緯度 var point = new GLatLng(lat, lon); createMarker(point) function createMarker(point) { var marker = new GMarker(point); map.addOverlay(marker); GEvent.addListener(marker, "click", function() { marker.openInfoWindowHtml(tags); }); } } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> マーカクリックで画像付き吹き出しを表示する <div id="map" style="width:500px; height:400px"></div> </body> </html>
住所/スポット名入力で地図を表示する
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head><title>Google Maps</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <script src="http://maps.google.com/maps?file=api&v=2&key=ABQIAAAAAO-r1bqRz2fZr-Q mjsewWxRgE_H9GM6zkZRwNii93jtvjOSYqRTUvjXBD0wChGoBh2xb30zNzkqZmA" type="text/javascript"></script> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA[ var map = null; var geocoder = null; function initOnLoad() { if (GBrowserIsCompatible()) { map = new GMap2(id("map")); map.setCenter(new GLatLng(35.6815617, 139.7672091), 1); map.addControl(new GLargeMapControl()); map.addControl(new GMapTypeControl()); geocoder = new GClientGeocoder(); setListener(id("addr"), "keyup", showMap); } }
gmaddr.htm
function showMap(e) { if(getkcode(e) == 18){ var addr = id("addr").value; if (geocoder) { geocoder.getLatLng( addr, function(point) { if (!point) { alert(addr + " が探せません。"); } else { map.setCenter(point, 15); var marker = new GMarker(point); map.addOverlay(marker); var msg = "ここへ到着、ここから出発<br/>付近を検索、マイマップに保存<br/>"; marker.openInfoWindowHtml(addr + "です。<br>" + msg); } }); } } } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> 住所/スポット名入力で地図を表示する<br/> <b>住所/スポット名</b><input type="text" size="59" id="addr"/> <div id="map" style="width: 500px; height: 370px"></div> </body> </html>
231 231
Yahoo! UI Library http://developer.yahoo.com/yui/
JavaScriptで記述され たWebクライアント用 総合ライブラリ
233 233
Animation Button Calendar Connection Dom DragDrop Event Logger Menu
Motion Panel Point Region Scroll Slider TabView TreeView YAHOO
Yahoo UI Library モジュール区分
234
Animation :ボックス拡大
235 235
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="content-type" content="text/html;charset=utf-8"> <title>anim1</title> <link rel="stylesheet" href="main.css" type="text/css" media="all"> <style type="text/css"> <!-- #box {width:100px; height:100px; background:#bbf;} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/build/yahoo/yahoo.js"></script> <script type="text/javascript" src="../lib/build/event/event.js"></script> <script type="text/javascript" src="../lib/build/dom/dom.js"></script> <script type="text/javascript" src="../lib/build/animation/animation.js"></script> <script type="text/javascript"> </script> </head> <body> <h2>ボックス拡大<input type="button" id="exe" value="開始"></h2> <div id="box">横幅と縦幅が指定された時間で変化。</div> </body> </html>
236 236
//<![CDATA[ function exeAnime(){ var boxObj = new YAHOO.util.Anim("box", { width: { from:100, to:320 }, height: { from:100, by:140 } }, 4.5 ); boxObj.animate(); } function setListeners(){ addListener($("exe"), "click", exeAnime, false); } addListener(window, "load", setListeners, false); //]]>
237
Animation :ボックス幅拡大
238 238
<style type="text/css"> <!-- #box {width:100px; height:100px; background:#bbf;} --> </style>
//<![CDATA[ function exeAnime(){ var boxObj = new YAHOO.util.Anim("box", { width: { from:100, to:320 } }); boxObj.animate(); } function setListeners(){ addListener($("exe"), "click", exeAnime, false); } addListener(window, "load", setListeners, false); //]]>
239
カレンダー1
240
<?xml version="1.0" encoding="utf-8" standalone="no"> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <title>カレンダー</title> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> <link type="text/css" rel="stylesheet" href="../lib/yui/build/calendar/assets/calendar.css" /> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/yui/build/yahoo/yahoo.js"></script> <script type="text/javascript" src="../lib/yui/build/event/event.js"></script> <script type="text/javascript" src="../lib/yui/build/dom/dom.js"></script> <script type="text/javascript" src="../lib/yui/build/calendar/calendar.js"></script> <script> //<![CDATA[ function init() { var calendar = new YAHOO.widget.Calendar("cal", "out", { pagedate:"2/2007", selected:"2/10/2007-2/15/2007" }); calendar.render(); } addListener(window, "load", init, false); //]]> </script> </head> <body><div id="out"></div></body> </html>
241
カレンダー2 2カ月表示
242
<?xml version="1.0" encoding="utf-8" standalone="no"> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <title>カレンダー</title> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> <link type="text/css" rel="stylesheet" href="../lib/yui/build/fonts/fonts.css" /> <link type="text/css" rel="stylesheet" href="../lib/yui/build/reset/reset.css" /> <link type="text/css" rel="stylesheet" href="../lib/yui/build/calendar/assets/calendar.css" /> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/yui/build/yahoo/yahoo.js"></script> <script type="text/javascript" src="../lib/yui/build/event/event.js"></script> <script type="text/javascript" src="../lib/yui/build/dom/dom.js"></script> <script type="text/javascript" src="../lib/yui/build/calendar/calendar.js"></script> <script> //<![CDATA[ function init() { var calendar = new YAHOO.widget.Calendar2up("cal", "out", { pagedate:"2/2007", selected:"2/13/2007-2/15/2007, 2/20/2007" }); calendar.render(); } addListener(window, "load", init, false); //]]> </script> </head> <body><div id="out"></div></body> </html>
243
カレンダー3 日本語表示
244
<?xml version="1.0" encoding="utf-8" standalone="no"> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <title>カレンダー</title> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> <link type="text/css" rel="stylesheet" href="../lib/yui/build/fonts/fonts.css" /> <link type="text/css" rel="stylesheet" href="../lib/yui/build/reset/reset.css" /> <link type="text/css" rel="stylesheet" href="../lib/yui/build/calendar/assets/calendar.css" /> <style> <!-- .yui-calendar td.wd0 { background-color:#fde0e0; } .yui-calendar td.wd0 a { color:red; } --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/yui/build/yahoo/yahoo.js"></script> <script type="text/javascript" src="../lib/yui/build/event/event.js"></script> <script type="text/javascript" src="../lib/yui/build/dom/dom.js"></script> <script type="text/javascript" src="../lib/yui/build/calendar/calendar.js"></script> <script> //<![CDATA[ function init() {} addListener(window, "load", init, false); //]]> </script> </head> <body><div id="out"></div></body> </html>
245
function init() { var cal1 = new YAHOO.widget.Calendar("cal1","out", { START_WEEKDAY: 1, MULTI_SELECT:true } ); cal1.cfg.setProperty("MDY_YEAR_POSITION", 1); cal1.cfg.setProperty("MDY_MONTH_POSITION", 2); cal1.cfg.setProperty("MDY_DAY_POSITION", 3); cal1.cfg.setProperty("MY_YEAR_POSITION", 1); cal1.cfg.setProperty("MY_MONTH_POSITION", 2); cal1.cfg.setProperty("MONTHS_SHORT",["1¥u6708", "2¥u6708", "3¥u6708", "4¥u6708", "5¥u6708", "6¥u6708", "7¥u6708", "8¥u6708", "9¥u6708", "10¥u6708", "11¥u6708", "12¥u6708"]); cal1.cfg.setProperty("MONTHS_LONG", ["1¥u6708", "2¥u6708", "3¥u6708", "4¥u6708", "5¥u6708", "6¥u6708", "7¥u6708", "8¥u6708", "9¥u6708", "10¥u6708", "11¥u6708", "12¥u6708"]); cal1.cfg.setProperty("WEEKDAYS_1CHAR", ["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.cfg.setProperty("WEEKDAYS_SHORT", ["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.cfg.setProperty("WEEKDAYS_MEDIUM",["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.cfg.setProperty("WEEKDAYS_LONG", ["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.select("2007/6/13-2007/6/20"); cal1.selectEvent.subscribe(function(eventName,selectDate){ alert(selectDate); },cal1, true); cal1.render(); }
246
日本語カレンダのドラッグ&ドロップ
247
<?xml version="1.0" encoding="utf-8" standalone="no"> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <title>カレンダー</title> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> <link type="text/css" rel="stylesheet" href="../lib/yui/build/fonts/fonts.css" /> <link type="text/css" rel="stylesheet" href="../lib/yui/build/reset/reset.css" /> <link type="text/css" rel="stylesheet" href="../lib/yui/build/calendar/assets/calendar.css" /> <style> <!-- #out {top:60px; left:60px} .yui-calendar td.wd0 { background-color:#fde0e0; } .yui-calendar td.wd0 a { color:red; } --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/yui/build/yahoo/yahoo.js"></script> <script type="text/javascript" src="../lib/yui/build/event/event.js"></script> <script type="text/javascript" src="../lib/yui/build/dom/dom.js"></script> <script type="text/javascript" src="../lib/yui/build/calendar/calendar.js"></script> <script type="text/javascript" src="../lib/yui/build/dragdrop/dragdrop.js"></script> <script> </script> </head> <body><div id="out"></div></body> </html>
248 248
//<![CDATA[ function init() { var cal1 = new YAHOO.widget.Calendar("cal1","out", { START_WEEKDAY: 1, MULTI_SELECT:true } ); cal1.cfg.setProperty("MDY_YEAR_POSITION", 1); cal1.cfg.setProperty("MDY_MONTH_POSITION", 2); cal1.cfg.setProperty("MDY_DAY_POSITION", 3); cal1.cfg.setProperty("MY_YEAR_POSITION", 1); cal1.cfg.setProperty("MY_MONTH_POSITION", 2); cal1.cfg.setProperty("MONTHS_SHORT",["1¥u6708", "2¥u6708", "3¥u6708", "4¥u6708", "5¥u6708", "6¥u6708", "7¥u6708", "8¥u6708", "9¥u6708", "10¥u6708", "11¥u6708", "12¥u6708"]); cal1.cfg.setProperty("MONTHS_LONG", ["1¥u6708", "2¥u6708", "3¥u6708", "4¥u6708", "5¥u6708", "6¥u6708", "7¥u6708", "8¥u6708", "9¥u6708", "10¥u6708", "11¥u6708", "12¥u6708"]); cal1.cfg.setProperty("WEEKDAYS_1CHAR", ["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.cfg.setProperty("WEEKDAYS_SHORT", ["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.cfg.setProperty("WEEKDAYS_MEDIUM",["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.cfg.setProperty("WEEKDAYS_LONG", ["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.select("2007/6/13-2007/6/20"); cal1.selectEvent.subscribe(function(eventName,selectDate){ alert(selectDate); },cal1, true); cal1.render(); ddBox = new YAHOO.util.DD("out"); } addListener(window, "load", init, false); //]]>
カレンダ使用での日付入力
<?xml version="1.0" encoding="utf-8" standalone="no"> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <title>カレンダー</title> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> <link type="text/css" rel="stylesheet" href="../lib/yui/build/fonts/fonts.css" /> <link type="text/css" rel="stylesheet" href="../lib/yui/build/reset/reset.css" /> <link type="text/css" rel="stylesheet" href="../lib/yui/build/calendar/assets/calendar.css" /> <style> <!-- #hdr { position:absolute; top:10px; left:30px; font-size: 20px; font-weight: 800; color: #c02; z-index:1;width:200px;height:25px;} #ord { position:absolute; top:50px; left:20px; font-size: 15px; z-index:1;width:155px;height:155px;} #cal { position:absolute; top:50px; left:250px; z-index:1;width:165px;height:165px;} .yui-calendar td.wd0 { background-color:#fde0e0; } .yui-calendar td.wd0 a { color:red; } --> </style>
calendar4.htm (1/4)
//<![CDATA[ var fid = "inqDate"; function init() { var cal1 = new YAHOO.widget.Calendar("cal1","cal", { START_WEEKDAY: 1, MULTI_SELECT:true } ); cal1.cfg.setProperty("MDY_YEAR_POSITION", 1); cal1.cfg.setProperty("MDY_MONTH_POSITION",2); cal1.cfg.setProperty("MDY_DAY_POSITION", 3); cal1.cfg.setProperty("MY_YEAR_POSITION", 1); cal1.cfg.setProperty("MY_MONTH_POSITION", 2); cal1.cfg.setProperty("MONTHS_SHORT",["1¥u6708", "2¥u6708", "3¥u6708", "4¥u6708", "5¥u6708","6¥u6708", "7¥u6708", "8¥u6708", "9¥u6708", "10¥u6708", "11¥u6708", "12¥u6708"]); cal1.cfg.setProperty("MONTHS_LONG", ["1¥u6708", "2¥u6708", "3¥u6708", "4¥u6708", "5¥u6708","6¥u6708", "7¥u6708", "8¥u6708", "9¥u6708", "10¥u6708", "11¥u6708", "12¥u6708"]); cal1.cfg.setProperty("WEEKDAYS_1CHAR", ["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.cfg.setProperty("WEEKDAYS_SHORT", ["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.cfg.setProperty("WEEKDAYS_MEDIUM",["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.cfg.setProperty("WEEKDAYS_LONG", ["¥u65E5", "¥u6708", "¥u706B", "¥u6C34", "¥u6728", "¥u91D1", "¥u571F"]); cal1.select("2007/6/13-2007/6/20");
calendar4.htm (2/4)
cal1.selectEvent.subscribe(function(eventName, selectDate){ var sdate1 = selectDate.toString(); var sdate2 = sdate1.replace(",", "/").replace(",", "/"); $(fid).value = sdate2; if(fid=="inqDate"){ fid = "ordDate"; }else if(fid == "ordDate"){ fid = "shpDate"; }else if(fid == "shpDate"){ fid = "payDate"; }else if(fid == "payDate"){ fid = "inqDate"; } },cal1, true); cal1.render(); } function setField(e) { fid = getid(e); } function listeners() { addListener($("entDay"), "click", setField, false); } addListener(window, "load", listeners, false); addListener(window, "load", init, false); //]]> </script>
calendar4.htm (3/4)
</head> <body> <p id="hdr">受注日付情報入力</p> <div id="ord"> <div>受注情報</div> <table width="200"> <tbody id="entDay"> <tr><td>問い合せ日</td><td><input type="text" size="8" id="inqDate"></td></tr> <tr><td>受注登録日</td><td><input type="text" size="8" id="ordDate"></td></tr> <tr><td>納入予定日</td><td><input type="text" size="8" id="shpDate"></td></tr> <tr><td>支払い期限</td><td><input type="text" size="8" id="payDate"></td></tr> </tbody> </table> </div> <div id="cal"></div></body> </html>
calendar4.htm (4/4)
254
[演習-3] 棒グラフをドラッグ&ドロップできるように修正して下さい
<?xml version="1.0" encoding="utf-8" standalone="no"> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <title>グラフ ドラッグ&ドロップ</title> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/plotr/plotr.js"></script> <script type="text/javascript" src="../lib/plotr/excanvas.js"></script> <script type="text/javascript" src="../lib/yui/build/yahoo/yahoo.js"></script> <script type="text/javascript" src="../lib/yui/build/event/event.js"></script> <script type="text/javascript" src="../lib/yui/build/dom/dom.js"></script> <script type="text/javascript" src="../lib/yui/build/dragdrop/dragdrop.js"></script> <script> //<![CDATA[ function drawGraph() { var dataset = { "y2006Q3": [[0, 1], [1, 1], [2, 1.2], [3, 1.5]], "y2007Q1": [[0, 0.5], [1, 0.89], [2, 2.15], [3, 4]], "y2007Q2": [[0, 0.2], [1, 0.79], [2, 3.95], [3, 3.2]], "y2007Q3": [[0, 1.2], [1, 2.79], [2, 4.95], [3, 5.2]] };
dragdrop3.htm (1/3)
var options = { padding: {left: 80, right: 0, top: 10, bottom: 10}, backgroundColor: "#dbdbdb", colorScheme: "#009", xTicks: [ {v:0, label:"商用Unix"}, {v:1, label:"FreeBSD"}, {v:2, label:"Linux"}, {v:3, label:"Windows"} ] }; var bar = new Plotr.BarChart("graph", options); bar.addDataset(dataset); bar.render(); ddBox = new YAHOO.util.DD("out"); } function setListeners(){ addListener($("draw"), "click", drawGraph, false); } addListener(window, "load", setListeners, false); //]]> </script> </head>
dragdrop3.htm (2/3)
<body> <h2>Draw Bar1 <input type="button" id="draw" value="グラフ表示" /></h2> <div id="out"><canvas id="graph" height="300" width="600"></canvas></div> </body> </html>
dragdrop3.htm (3/3)
258
Yahoo! UI Library カレンダー表示
テーブルでのCRUD処理:使用される要素技術とライブラリ
[要素技術とライブラリ] ①イベント処理 -DOMモデルでのイベント伝播 +funcs.js ②サーバ通信 -配列データのサーバ送受信 +DWRでのJavaサーバ開発 ③+④+⑤表示制御 -DOMノード操作での動的 ・テーブル行/列追加 ・テーブル行/列挿入 +funcs.js
テーブル表示 (標準DOMノード操作)
テーブル表示
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>Ajax Table Create</title> <style type="text/css"> <!-- .t1 {bgcolor: #ccccff;} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA function cr_tbl(){ var rows = 10, cols = 6; var table = document.createElement("table"); table.setAttribute("border", "1"); var thead = document.createElement("thead"); var tr = document.createElement("tr"); for(var j = 0; j < cols; j++){ var td = document.createElement("td"); td.setAttribute("align", "center");
if(j==0){ td.setAttribute("width", "40"); var title = document.createTextNode(" "); }else{ var title = document.createTextNode("列" + (j-1)); } td.appendChild(title); tr.appendChild(td); } thead.appendChild(tr); var tbody = document.createElement("tbody"); for(var i = 0; i < rows; i++){ var tr = document.createElement("tr"); for(var j = 0; j < cols; j++){ var td = document.createElement("td"); td.setAttribute("align", "center"); if(j==0){ td.setAttribute("width", "40"); td.setAttribute("class", "t1"); var title = document.createTextNode("行" + i); }else{ td.setAttribute(“width”, “80”); var title = document.createTextNode("ID " + i + ":" + j); } td.appendChild(title); tr.appendChild(td); }
tbody.appendChild(tr); } table.appendChild(thead); table.appendChild(tbody); document.getElementById("view").appendChild(table); } function initOnLoad() { var observer = document.getElementById("sel"); setListener(observer, "click", cr_tbl); } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> <center> <h3>テーブル表示 <input type="button" id="sel" value=" 表示 "/></h3> <p id="view"></p> </center> </body> </html>
テーブル表示(HTML TableElementインターフェイスを使用)
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>Ajax Table Create</title> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA function cr_tbl(){ var rows = 10, cols = 6; var table = document.createElement("table"); table.id = "out"; table.border = "1"; table.createTHead(); var tr = table.insertRow(0); for(var j = 0; j <cols6; j++){ var td = tr.insertCell(j); td.align ="center"; if(j==0){ td.width = "40"; td.appendChild(document.createTextNode(" ")); }else{ td.width = "80"; td.appendChild(document.createTextNode("列" + (j-1))); } }
for(var i = 0; i < rows; i++){ var tr = table.insertRow(i+1); for(var j = 0; j < cols; j++){ var td = tr.insertCell(j); td.align = "center"; if(j==0){ td.width = "40"; td.appendChild(document.createTextNode("行" + i)); }else{ td.width = "80"; td.appendChild(document.createTextNode("ID " + i + ":" + j)); } } } document.getElementById("view").appendChild(table); } function initOnLoad(){ var observer = document.getElementById("sel"); setListener(observer, "click", cr_tbl); } setListener(window, "load", initOnLoad); //]]> </script> </head> <body> <center> <h3>テーブル表示 <input type="button" id="sel" value=" 表示 "/></h3> <p id="view"></p> </center> </body> </html>
[演習-4] ボタンクリックで下図のようなテーブルを表示するプログラムを 作成してください(行数・列数は任意です)。
テーブルでの参照・登録・更新・削除-1 テーブル:行追加、列追加、行挿入、列挿入
サーバ :表データの登録、参照、更新、削除(crud)
テーブルでの参照・登録・更新・削除-2
テーブル応用画面 セレクトメニューからの選択と自動カウント
テーブル応用画面
272 272 272
http://www.activewidgets.com/
ActiveWidgets ・AjaxでのRIA構築に向けた UIコントロールライブラリ ・HTMLフォームコントロール との共用可 ・GPLと商用ライセンスの デュアル・ライセンスで配布
273 273
ActiveWidgetsインストール手順
http://www.activewidgets.com/ からトライアル版ダウンロード・解凍後、下記css、jsァイル指定
<link rel="stylesheet" type="text/css" href="../lib/aw.css"/> <script type="text/javascript" src="../lib/aw.js"></script>
274 274 274
[2] JavaScript関数での実行 (1) タブコントロール
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>ActiveWidgets Examples</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <link href="awidgets/runtime/styles/xp/aw.css" rel="stylesheet"></link> <link rel="stylesheet" type="text/css" href="./lib/style.css" />
コード12(1/3)
275 275 275
<style type="text/css"> #menuTabs {width: 850px; height:30 px;} // Tabs #memuTabs .aw-list-item {color: blue} // Items </style> <script type="text/javascript" src="awidgets/runtime/lib/aw.js"></script> <script type="text/javascript" src="./lib/funcs.js"></script> <script type="text/javascript"> //<![CDATA[ var httpObj = getHttpObject(); function tabs1(){ var menu; var sp ="   " var tabs = new AW.UI.Tabs; tabs.setId("menuTabs"); // necessary for CSS rules tabs.setItemText(["Ajaxの概要", "要素技術 ", "Ajax応用例", "JS機能拡張", "UI表示ー1", "UI表示ー2", "Backbase ", "サーバサイド", "Webサービス ", "セキュリティ "]); tabs.setItemCount(8); // same as setViewCount() tabs.refresh();
コード12(2/3)
276 276 276
コード12(2/3)
tabs.onSelectedItemsChanged = function(array){
if(array == "0"){
menu = "ajax.txt";
}else if(array == "1"){
menu = "tec.txt";
}else if(array == "2"){
menu = "app.txt";
}else if(array == "3"){
:
}
httpObj.open("get", menu, false);
httpObj.send(null);
var indata = httpObj.responseText;
document.getElementById("menu").innerHTML = indata;
}
}
addListener(window, "load", tabs1, false);
//]]>
</script>
277 277 277
</head> <body> <div class="t3"> Ajax サイト&サンプル</div> <div> 本サイトへのお問合せは右記メールアドレスへお願いします。([email protected]) <div> 方法/理由の如何を問わず本サイト掲載プログラムの無断コピーを禁止します。</div> <p id="menuTabs"><div style="border-top: 1px solid #999"></div></p> <p id="menu"></p> </body> </html>
コード12(3/3)
278 278 278
(3) コンボボックス
279 279 279
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>ActiveWidgets Examples</title> <link href="../awidgets/runtime/styles/xp/aw.css" rel="stylesheet"></link> <style type="text/css"> #combo1 {width: 90px; height: 22px} #combo1-popup {width: 80px; height: 80px; border: 3px double #69f;} #combo1-popup .aw-mouseover-item {background: #330099} </style> <script src="../awidgets/runtime/lib/aw.js"></script> <script type="text/javascript" src="../funcs.js"></script> <script type="text/javascript"> function showCombo(){ var combo = new AW.UI.Combo; //コンボインスタンス生成 combo.setId("combo1"); //コンボ表示タグID指定 combo.setControlText("東京"); //初期表示テキスト指定 combo.setItemText(["埼玉", "神奈川", "千葉", "山梨"]); //リスト表示項目指定 combo.setItemCount(4); //リスト表示項目数指定 combo.refresh(); //コンボ表示 combo.onControlClicked = function(event){ window.status = "Control clicked"}; combo.onControlDoubleClicked = function(event){ window.status = "Control double clicked"};
コード17(1/2)
280 280 280
combo.onControlMouseOver = function(event){ window.status = "Control mouse over"}; combo.onControlMouseOut = function(event){ window.status = "Control mouse out"}; combo.onControlMouseDown = function(event){ window.status = "Control mouse down"}; combo.onControlMouseUp = function(event){ window.status = "Control mouse up"}; combo.onControlTextChanged = function(text){ window.status = "control text: “ + text; alert(“選択は: ” + text); }; combo.onControlActivated = function(event){ window.status = "control activated"}; combo.onControlDeactivated = function(event){ window.status = "control deactivated"}; combo.onControlEditStarted = function(event){ window.status = "control edit started"}; combo.onControlEditEnded = function(event){ window.status = "control edit ended"}; } addListener(self, "load", showCombo, false); </script> </head> <body> <p id="combo1"><p> </body> </html>
コード17(2/2)
281
[演習-4] スプレッドシート作成 ・コンボボックスで行、列を指定できるようにする ・行と列を選択後、選択された行、列をアラート表示 ⇒この後の演習で、指定された行数列数のグリッドを表示
//<![CDATA[ var rows, cols; var rowcb = new AW.UI.Combo; // Create combo box var colcb = new AW.UI.Combo; // Create combo box function setRowColSel(){ rowcb.setId("rows"); rowcb.setControlSize(51, 22); // Set combo size width, height rowcb.setControlText("0"); // Iniital display item rowcb.setItemText(["1","2","3","4","5","6","7","8","9","10","11","12","13","14","15"]); rowcb.setItemCount(15); // Drop down items and count $("rows").innerHTML=rowcb; colcb.setId("cols"); colcb.setControlSize(51, 22); // Set combo size width, height colcb.setControlText("0"); // Iniital display item colcb.setItemText(["1","2","3","4","5","6","7","8","9","10","11","12","13","14","15"]); colcb.setItemCount(15); // Drop down items and count $("cols").innerHTML=colcb; rowcb.onControlTextChanged = function(rows1){ window.status = "rows: " + rows1; } colcb.onControlTextChanged = function(cols1){ window.status = "cols: " + cols1; } } addListener(self, "load", setRowColSel, false); //]]>
spread1.js
283 283 283
グリッドコントロール サンプル2 ・イベントハンドラ使用の関数呼び出し形式
284 284 284
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>ActiveWidgets Examples</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <link rel="stylesheet" href="../awidgets/runtime/styles/xp/aw.css"/> <link rel="stylesheet" href="grid1.css"/> <script type="text/javascript" src="../funcs.js"></script> <script type="text/javascript" src="../awidgets/runtime/lib/aw.js"></script> <script type="text/javascript" src="grid1.js"></script> </head> <body> <center> <h3>グリッド表示サンプル</h3> <p id="grid1"></p> </center> </body> </html>
グリッド表示サンプル XHTML grid1.htm
285 285 285
グリッド表示サンプル CSS grid1.css
<!-- #grid1 .aw-grid-row {height: 20px; border-bottom: 1px solid #ccc} #grid1 .aw-alternate-even {background: #fff;} #grid1 .aw-alternate-odd {background: #eee;} #grid1 .aw-alternate-even .aw-column-1 {background: #eee;} #grid1 .aw-alternate-odd .aw-column-1 {background: #ddd;} #grid1 .aw-rows-selected {background: #316ac5;} #grid1 .aw-rows-selected .aw-column-1 {background: #316ac5;} #grid1 .aw-column-0 {width: 50px; border-right: 1px dotted #ccc;} #grid1 .aw-column-1 {width: 150px; border-right: 1px dotted #ccc;} #grid1 .aw-column-2 {text-align: right} #grid1 .aw-column-3 {text-align: right} #grid1 .aw-column-4 {text-align: right} #grid1 .aw-mouseover-cell {color: red;} #grid1 .aw-grid-row .aw-cells-selected {background: #316ac5;} #grid1 .aw-grid-headers {color: blue} #grid1 .aw-grid-headers .aw-column-1 {font-weight: bold} #grid1 .aw-mouseover-header {color: red;} #grid1 .aw-mousedown-header {color: yellow;} #grid1 .aw-header-1 {background: #def} #grid1 .aw-row-selector {width: 20px; text-align: center} #grid1 .aw-row-2 .aw-row-selector {font-weight: bold} #grid1 .aw-mouseover-row .aw-row-selector {color: red;} #grid1 .aw-mouseover-selector {background: green;} #grid1 .aw-mousedown-selector {background: yellow;} -->
286 286 286
グリッド表示サンプル JavaScript
//<![CDATA[ function grid1(){ var data1 = [ ["MSFT","Microsoft Corporation", "314,571.156", "32,187.000", "55000"], ["ORCL", "Oracle Corporation", "62,615.266", "9,519.000", "40650"], ["SAP", "SAP AG (ADR)", "40,986.328", "8,296.420", "28961"], ["CA", "Computer Associates Inter", "15,606.335", "3,164.000", "16000"], ["ERTS", "Electronic Arts Inc.", "14,490.895", "2,503.727", "4000"], ["SFTBF", "Softbank Corp. (ADR)", "14,485.840", ".000", "6865"], ["VRTS", "Veritas Software Corp.", "14,444.272", "1,578.658", "5647"], ["SYMC", "Symantec Corporation", "9,932.483", "1,482.029", "4300"], ["INFY", "Infosys Technologies Ltd.", "9,763.851", "830.748", "15400"], ["INTU", "Intuit Inc.", "9,702.477", "1,650.743", "6700"], ["ADBE", "Adobe Systems Incorporate", "9,533.050", "1,230.817", "3341"], ["PSFT", "PeopleSoft, Inc.", "8,246.467", "1,941.167", "8180"], ["SEBL", "Siebel Systems, Inc.", "5,434.649", "1,417.952", "5909"], ["BEAS", "BEA Systems, Inc.", "5,111.813", "965.694", "3063"], ["SNPS", "Synopsys, Inc.", "4,482.535", "1,169.786", "4254"], ["CHKP", "Check Point Software Tech", "4,396.853", "424.769", "1203"], ["MERQ", "Mercury Interactive Corp.", "4,325.488", "444.063", "1822"], ["DOX", "Amdocs Limited", "4,288.017", "1,427.088", "9400"], ["CTXS", "Citrix Systems, Inc.", "3,946.485", "554.222", "1670"], ["KNM", "Konami Corporation (ADR)", "3,710.784", ".000", "4313"] ]; var myHeaders = [“ティカー”, “会社名”, “マーケット”, “$セールス”, “従業員数”]; //グリッドタイトルの指定
grid1.js(1/2)
287 287 287
var obj = new AW.Grid.Extended; //グリッドオブジェクトの生成 obj.setId("grid1"); //グリッドのCSS 書式への対応 obj.setFixedLeft(1); //左側固定カラム数の指定 obj.setControlSize(500, 300); //グリッド幅と高さ指定 obj.setControlPosition(100, 50); //グリッド左上位置指定 obj.setCellText(data1); // 2-dimensional js array obj.setCellEditable(true); //セルを編集可能に指定 obj.setHeaderText(myHeaders); //グリッドタイトルの書き込み obj.setColumnCount(5); //グリッドカラム数指定 obj.setRowCount(20); //グリッド行数指定 document.getElementById("grid1").innerHTML = obj; obj.onCellClicked = function(event, column, row){ window.status = "Cell " + column + "." + row + " clicked" alert("セル " + column + "." + row + " クリックド"); } obj.onCellDoubleClicked = function(event, column, row){ window.status = "Cell " + column + "." + row + " clicked" alert("セル " + column + "." + row + " ダブルクリックド"); } } addListener(self, "load", grid1, false); //]]>
grid1.js(2/2)
288 288 288
グリッドコントロール サンプル4 行列指定でのグリッド表示とデータベース登録・更新・参照・削除
289 289 289
XHTML
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <meta http-equiv="pragma" content="no-cache"> <meta http-equiv="Cache-Control" content="no-cache"> <meta http-equiv="Expires" content="Thu, 01 Dec 1994 16:00:00 GMT"> <title>ActiveWidgets Examples</title> <link rel="stylesheet" href="../awidgets/runtime/styles/xp/aw.css"/> <link rel="stylesheet" href="../style.css"/> <link rel="stylesheet" href="spread.css"/> <script type="text/javascript" src="../awidgets/runtime/lib/aw.js"></script> <script type="text/javascript" src="../funcs.js"></script> <script type="text/javascript" src="spread.js"></script> </head> <body> <center> <table> <tr> <th>テーブル入力処理-V</th> <td id="mod"> <button type="button" class="b3" id="rev">参照</button> <button type="button" class="b3" id="add">登録</button> <button type="button" class="b3" id="upd">更新</button>
コード30(1/2)
290 290 290
<button type="button" class="b3" id="del">削除</button> </td> </tr> </table> <table><tr><td id="status"> </td></tr></table> <table> <tr> <td id="tinf"></td> <td>  </td> <td>行数指定</td><td id="rows"></td> <td>  </td> <td>列数指定</td><td id="cols"></td> </tr> </table> <table><tr><td id="tout"></td></tr></table> </center> </body> </html>
コード30(2/2)
291 291 291
CSS
<!-- #rows {width: 100px; height: 22px} #rows-popup {width: 40px; height: 170px; border: 1px double #30f;} #rows-popup .aw-mouseover-item {background: #330099} #cols {width: 100px; height: 22px} #cols-popup {width: 40px; height: 170px; border: 1px double #30f;} #cols-popup .aw-mouseover-item {background: #330099} #myGrid .aw-grid-row {height: 20px; border-bottom: 1px solid #ccc} #myGrid .aw-alternate-even {background: #fff;} #myGrid .aw-alternate-odd {background: #eee;} #myGrid .aw-column-0 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-1 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-2 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-3 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-4 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-5 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-6 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-7 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-8 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-9 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-10 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-11 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-12 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-13 {width: 80px; border-right: 1px dotted #ccc;}
コード31(1/2)
292 292 292
#myGrid .aw-column-14 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-15 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-16 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-17 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-18 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-column-19 {width: 80px; border-right: 1px dotted #ccc;} #myGrid .aw-grid-row .aw-cells-selected {background: #cacaca;} #myGrid .aw-mouseover-header {color: red;} #myGrid .aw-mousedown-header {color: yellow;} #myGrid .aw-header-1 {background: #eee} #myGrid .aw-row-selector {width: 20px; text-align: center} #myGrid .aw-mouseover-row .aw-row-selector {color: red;} #myGrid .aw-mouseover-selector {background: green;} #myGrid .aw-mousedown-selector {background: yellow;} -->
コード31(2/2)
293 293 293
//<![CDATA[ var httpObj = getHttpObject(); var table_name, recs; var rows, cols; var myData = new Array(); var myHeaders = new Array(); var obj = new AW.Grid.Extended; var obj1 = new AW.UI.Combo; // Create combo box var obj2 = new AW.UI.Combo; // Create combo box function setRowColSel(){ obj1.setId("rows"); obj1.setControlSize(51, 22); // Set combo size width, height obj1.setControlText("0"); // Iniital display item obj1.setItemText(["1","2","3","4","5","6","7","8","9","10"]); obj1.setItemCount(10); // Drop down items and count document.getElementById("rows").innerHTML=obj1; obj2.setId("cols"); obj2.setControlSize(51, 22); // Set combo size width, height obj2.setControlText("0"); // Iniital display item obj2.setItemText(["1","2","3","4","5","6","7","8","9","10"]); obj2.setItemCount(10); // Drop down items and count document.getElementById("cols").innerHTML=obj2; obj1.onControlTextChanged = function(rows1){ rows = rows1; window.status = "control text: " + rows; }
JavaScript コード21(1/8)
294 294 294
obj2.onControlTextChanged = function(cols1){ cols = cols1; window.status = "control text: " + cols; } obj2.onControlDeactivated = function(cols1){ window.status = "control text: " + rows + ":" + cols; showGrid(rows, cols, "new"); addTblHdr(rows, cols); } } function showGrid(rows, cols, flag){ var i, j, k, row, col, cell_text; if(flag=="new"){ //新規テーブル表示処理 myData = new Array(rows); for(i=0; i<rows; i++){ myData[i] = new Array(cols); } for(i=0; i<rows; i++){ for(j=0; j<cols; j++){ myData[i][j] = ""; } } }else if(flag=="upd"){ //既存テーブル表示処理 myData = new Array(rows);
コード21(2/8)
295 295 295
for(j=0; j<rows; j++){ myData[j] = new Array(cols); } for(j=0; j<rows; j++){ for(k=0; k<cols; k++){ myData[j][k] = ""; } } for(i=1; i < (recs.length-1); i++){ //サーバ受信データを表示用配列にセット rec = recs[i].split("<i>"); row = rec[0]; col = rec[1]; cell_text = rec[2]; myData[row][col] = cell_text; } obj1.setControlText(rows); obj2.setControlText(cols); } for (i = 0; i < cols; i++){ //テーブル列ヘッダの設定 myHeaders[i] = i+1; } obj.setId("myGrid"); //適用スタイルの指定 var gridw, gridh, selfw, offx; if(cols > 10 && rows > 18){ gridw = 740; // グリッド幅指定 gridh = 460; // グリッド高さ指定 }else if(cols <= 10 && rows > 18){
コード21(3/8)
296 296 296
gridw = 28 + 80 * cols; gridh = 460; }else if(cols > 10 && rows <= 18){ gridw = 740; gridh = 28 + 20 * rows; }else if(cols <= 10 && rows <=18){ gridw = 28 + 80 * cols; gridh = 28 + 20 * rows; } obj.setControlSize(gridw, gridh); //グリッド幅と高さ指定 obj.setCellText(myData); //2-dimensional js array obj.setCellEditable(true); //セル編集可能指定 obj.setHeaderCount(1); obj.setHeaderText(myHeaders); //テーブル列ヘッダ表示 obj.setRowCount(rows); //行数指定 obj.setColumnCount(cols); //列数指定 obj.setSelectorText(function(i){return this.getRowPosition(i)+1}); //テーブル行ヘッダ表示 obj.setSelectorVisible(true); document.getElementById("myGrid").innerHTML = obj; //テーブル表示 } function addTblHdr(rows, cols){ table_name = document.getElementById("table_name").value; httpObj.open("post", "../addtablehdr", false);
コード21(4/8)
297 297 297
httpObj.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); httpObj.send("table_name="+table_name+"&rows="+rows+"&cols="+cols); document.getElementById("status").innerText = httpObj.responseText; } function checkFname(e){ var i, j, k, get, get2, msg, out, cellid; if(e.keyCode == 18){ table_name = document.getElementById("table_name").value; httpObj.open("get", "../settablefile?table_name="+table_name, false); httpObj.setRequestHeader("If-Modified-Since", "01 Jan 1970 00:00:00 GMT"); httpObj.send(null); get = httpObj.responseText.split(","); if(get[0]=="new"){ msg = "新規ファイル作成です。"; document.getElementById("status").innerText = msg; }else{ msg = "ファイル " + table_name + " は存在しています。" document.getElementById("status").innerText = msg; out = "<table align='center'>"; out = "<table align='center' cellspacing='0' cellpadding='0'>"; for(i = 0; i < get[1]; i++){ out += "<tr>"; for(j = 0; j < get[2]; j++) out += "<td><input type='text' id='"+i+":"+j+"' size='5'/></td>"; out += "</tr>"; }
コード21(5/8)
298 298 298
out += "</table>"; document.getElementById("out2").innerHTML = out; document.getElementById("rows").value = get[1]; document.getElementById("cols").value = get[2]; httpObj.open("get", "../gettabledtl?table_name="+table_name, false); httpObj.setRequestHeader("If-Modified-Since", "01 Jan 1970 00:00:00 GMT"); httpObj.send(null); get = httpObj.responseText.split("<p>"); for(k = 0; k < get.length; k++){ get2 = get[k].split(","); cellid = get2[0] + ":" + get2[1]; document.getElementById(cellid).innerText = get2[2]; } } } } function revGrid(){ var table_name = document.getElementById("table_name").value; httpObj.open("post", "../revgrid", true); httpObj.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); httpObj.setRequestHeader("If-Modified-Since", "01 Jan 2000 00:00:00 GMT"); httpObj.send("table_name="+table_name); httpObj.onreadystatechange = function(){ if(httpObj.readyState == 4){ if(httpObj.status == 200){ recs = httpObj.responseText.split("<r>");
コード21(6/8)
299 299 299
var1 = recs[0].split("<i>"); rows = var1[0]; cols = var1[1]; showGrid(rows, cols, "old"); } } } } function modGrid(e){ var params, vals; var table_name = document.getElementById("table_name").value; var eid = getid(e); if(eid=="add"){ httpObj.open("post", "../addgrid", false); }else if(eid=="upd"){ httpObj.open("post", "../updgrid", false); }else if(eid=="del"){ httpObj.open("post", "../delgrid", false); } httpObj.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); httpObj.setRequestHeader("If-Modified-Since", "01 Jan 2000 00:00:00 GMT"); if(eid=="add" || eid=="upd"){ parms = new Array(table_name, rows, cols); vals = parms.concat(myData); httpObj.send("vals="+vals); }else if(eid="del"){
コード21(7/8)
300 300 300
httpObj.send("table_name="+table_name); } document.getElementById("status").innerText = httpObj.responseText; } function setListeners(){ var eSrc = document.getElementById("table_name"); addListener(eSrc, "keyup", checkFname, false); var eSrc = document.getElementById("rev"); addListener(eSrc, "click", revGrid, false); var eSrc = document.getElementById("mod"); addListener(eSrc, "click", modGrid, false); } addListener(self, "load", setListeners, false); addListener(self, "load", setRowColSel, false); //]]>
コード21(8/8)
301
[演習-5] スプレッドシート作成
コンボボックスで指定した行、列でグリッド表示
302
行、列演算機能の追加
//<![CDATA[ : var col1 = -1, row1 = -1, col2 = -1, row2 = -1; : function showGrid(rows, cols, flag){ : grid.onCellClicked = function(event, ecol, erow){ window.status = "Cell " + ecol + "." + erow + " clicked"; if(mode == "sumr"){ calcRowSum(ecol, erow); }else if(mode == "sumc"){ calcColSum(ecol, erow); } } }
function calcRowSum(ecol, erow){ if(col1 >= 0 && row1 >= 0){ col2 = ecol; row2 = erow; if(col2 > col1 && row1 == row2){ sum = parseFloat(0); for(i = col1; i <= col2; i++){ if(isNaN(parseFloat(cdat[row1][i])) != true){ sum += parseFloat(cdat[row1][i]); } } cdat[row1][++col2] = sum; grid.setId("grid"); grid.setCellText(cdat); // 2-dimensional js array $("grid").innerHTML = grid; col1 = -1; row1 = -1; col2 = -1; row2 = -1; } }else{ col1 = ecol; row1 = erow; } }
行計算関数
function calcColSum(ecol, erow){ if(col1 >= 0 && row1 >= 0){ col2 = ecol; row2 = erow; if(row2 > row1 && col1 == col2){ sum = parseFloat(0); for(i = row1; i <= row2; i++){ if(isNaN(parseFloat(cdat[i][col1])) != true){ sum += parseFloat(cdat[i][col1]); } } cdat[++row2][col1] = sum; grid.setId("grid"); grid.setCellText(cdat); // 2-dimensional js array $("grid").innerHTML = grid; col1 = -1; row1 = -1; col2 = -1; row2 = -1; } }else{ col1 = ecol; row1 = erow; } }
列計算関数
306
演習-6 スプレッドシート作成
ファイル名でデータ参照機能の追加
function revGrid(){ var table_name = dwr.util.getValue("table_name"); spread.revGrid(table_name, revGridExe); } function revGridExe(resp){ recs = resp.split("<r>"); var1 = recs[0].split("<i>"); rows = var1[0]; cols = var1[1]; showGrid(rows, cols, "upd"); }
演習-6 ヒント グリッドデータのサーバアクセス処理
function showGrid(rows, cols, flag){ var i, j, k, row, col, cell_text; if(flag == "new"){ : }else if(flag=="upd"){ cdat = new Array(rows); for(j=0; j<rows; j++){ cdat[j] = new Array(cols); } for(j=0; j<rows; j++){ for(k=0; k<cols; k++){ cdat[j][k] = ""; } } for(i=1; i < (recs.length-1); i++){ rec = recs[i].split("<i>"); row = rec[0]; col = rec[1]; cell_text = rec[2]; cdat[row][col] = cell_text; } rowcb.setControlText(rows); colcb.setControlText(cols); } :
受信データの配列セット (1/2)
grid.setControlSize(gridw, gridh); // グリッド幅と高さ指定 grid.setCellText(cdat); // 2-dimensional js array grid.setCellEditable(true); // enable editing grid.setHeaderCount(1); grid.setHeaderText(headers); // js array (see top of this page) grid.setRowCount(rows); // 行数指定 grid.setColumnCount(cols); // 列数指定 grid.setSelectorText(function(i){return this.getRowPosition(i);}); grid.setSelectorVisible(true); grid.setFixedLeft(fixedCols); $("grid").innerHTML = grid; grid.onCellClicked = function(event, ecol, erow){ window.status = "Cell " + ecol + "." + erow + " clicked"; if(mode == "sumr"){ calcRowSum(ecol, erow); }else if(mode == "sumc"){ calcColSum(ecol, erow); } } }
受信データの配列セット (2/2)
Webスプレッドシート ブラウザでのスプレッドシート処理
DWRでの Ajaxクライアント + サーバサイドJava 構成
・行、列の動的追加と削除 ・行列演算機能
・マクロ演算機能 ・CSVファイル読み込み
・グリッド表示データのグラフ表示(棒グラフ、折線グラフ、円グラフ)
UIとサーバ通信の分離
Ajaxエンジン
⑤演算処理 ④表示制御
①イベント処理
②サーバ通信
③UI表示
Web GUI
DWR 他コンポーネント
DB
DWRサーブレット
Java Beans (POJO)
ActiveWidgets
plotr
グリッドでのCRUD処理:使用される要素技術とライブラリ
[要素技術とライブラリ] ①イベント処理 -ActiveWidgetsイベント処理 +funcs.js ②サーバ通信 +DWRでのJavaサーバ開発 +DWRでの配列データ送信 ③+④+⑤表示制御 +ActiveWidgetsグリッド処理 +ActiveWidgetsコンボ処理 +plotrでのグラフ表示 +funcs.js
行合計表示
列合計表示
行列総合計表示
行列総平均表示
(1,8) = (1,2) * (1,3) (2,8) = (1,7) - (1,6) * 2 マクロ登録と実行
CSVファイル読み込み
棒グラフ表示(縦)
棒グラフ表示(横)
折れ線グラフ表示
円グラフ表示
Appendix
320 320 320
http://www.activewidgets.com/
ActiveWidgets ・AjaxでのRIA構築に向けた UIコントロールライブラリ ・HTMLフォームコントロール との共用可 ・GPLと商用ライセンスの デュアル・ライセンスで配布
321 321
ActiveWidgetsインストール手順
http://www.activewidgets.com/ からトライアル版ダウンロード・解凍後、下記css、jsァイル指定
<link rel="stylesheet" type="text/css" href="../lib/aw.css"/> <script type="text/javascript" src="../lib/aw.js"></script>
322 322 322
1 グリッド <html> <head> <title>ActiveWidgets Examples</title> <script src="../awidgets/runtime/lib/aw.js"></script> <link href="../awidgets/runtime/styles/xp/aw.css" rel="stylesheet"/> <style>#grid1 {width: 400px; height: 100px}</style> </head> <body> <p id="grid1"></p> <script> var grid1 = new AW.UI.Grid; //グリッドインスタンス生成 grid1.setId("grid1"); //表示タグ位置ID指定 grid1.setCellText("cell"); //セル表示テキスト指定 grid1.setHeaderText("header"); //カラムヘッダ指定 grid1.setColumnCount(5); //表示カラム数指定 grid1.setRowCount(10); //表示行数指定 grid1.refresh(); //グリッド表示 </script> </body> </html>
コード1
[1] 簡単なサンプル -bodyタグ内での実行 -ActiveWidgetsオリジナル
323 323 323
2 タブ
<html> <head> <title>ActiveWidgets Examples</title> <script src="../awidgets/runtime/lib/aw.js"></script> <link href="../awidgets/runtime/styles/xp/aw.css" rel="stylesheet"/> </head> <body> <p id="tabs1"></p> <div style="border-top:1px solid #999; font-size:1px; width:300px"/> <script> var itemTextArray = ["Home", "Favorites", "Font size", "Search"]; //各タブ表示テキスト指定 var itemImageArray = ["home", "favorites", "fontsize", "search"]; //各タブ表示画像指定 var tabs = new AW.UI.Tabs; //タブインスタンス生成 tabs.setId("tabs1"); //タブ表示タグ位置ID指定 tabs.setItemText(itemTextArray); //タブへの表示テキスト割り当て tabs.setItemImage(itemImageArray); //タブへの表示画像割り当て tabs.setItemCount(4); //表示タブ数指定 tabs.setSelectedItems([0]); //左端のタブ(Home)を初期表示選択に指定 tabs.refresh(); //タブ表示 </script> </body> </html>
コード2
324 324 324
3 コンボボックス
<html> <head> <title>ActiveWidgets Examples</title> <script src="../awidgets/runtime/lib/aw.js"></script> <link href="../awidgets/runtime/styles/xp/aw.css" rel="stylesheet"></link> </style> </head> <body class="aw-background-1"> <p>Combo:</p><p id="combo1"></p> <script> var itemTextArray = ["Home", "Favorites", "Font size", "Search"]; //コンボリスト表記テキスト項目指定 var itemImageArray = ["home", "favorites", "fontsize", "search"]; //コンボリスト表示画像項目指定 var combo = new AW.UI.Combo; //コンボインスタンス生成 combo.setId("combo1"); //コンボ表示タグ位置ID指定 combo.setControlText("Combo"); //ボックス内初期表示テキスト指定 combo.setControlImage("favorites"); //ボックス内初期表示画像(星印)指定 combo.setItemText(itemTextArray); //コンボリストへのテキスト割り当て
コード3(1/2)
325 325 325
combo.setItemImage(itemImageArray); //コンボリストへの画像割り当て combo.setItemCount(4); //コンボリスト項目数指定 combo.refresh(); //コンボ表示 </script> </body> </html>
コード3(2/2)
326 326 326
4 ツリー
<html> <head> <title>ActiveWidgets Examples</title> <script src="../awidgets/runtime/lib/aw.js"></script> <link href="../awidgets/runtime/styles/xp/aw.css" rel="stylesheet"/> </head> <body> <p id="tree1"></p> <script> var treeText = ["", "Home", "Favorites", "Font size", "Search", "Child node 1", "Child node 2"]; //ツリー表示テキスト指定 var treeImage = ["", "home", "favorites", "fontsize", "search"]; //ツリートップ表示画像指定 var treeView = {0:[1, 2, 3, 4], 1:[5, 6], 2:[7], 3:[8], 4:[9]}; //ツリー表示テキストをツリー構造に割り当て
コード4(1/2)
327 327 327
var tree = new AW.UI.Tree; //ツリーインスタンス生成 tree.setId("tree1"); //ツリー表示タグ位置ID指定 tree.setItemText(treeText); //ツリーへの表示テキスト割り当て tree.setItemImage(treeImage); //ツリーへの表示画像割り当て tree.setViewCount(function(i){return treeView[i] ? treeView[i].length : 0}); //トップレベル表示項目数指定 tree.setViewIndices(function(i){return treeView[i]}); tree.refresh(); //ツリー表示 </script> </body> </html>
コード4(2/2)
328
[実習-3] ・グリッド、タブメニュー、コンボボックス、 ツリーをディレクトリにコピーし機能確認 して下さい。
329 329 329
5 チェックリスト
<html> <head> <title>ActiveWidgets Examples</title> <script src="../awidgets/runtime/lib/aw.js"></script> <link href="../awidgets/runtime/styles/xp/aw.css" rel="stylesheet"></link> </head> <body> <p id="checkedList1"></p> <script> var itemTextArray = ["Home", "Favorites", "Font size", "Search"]; //チェックボックス表示テキスト指定 var itemImageArray = ["home", "favorites", "fontsize", "search"]; //チェックボックス表示画像指定 var checkedList = new AW.UI.CheckedList; //チェックボックスインスタンス生成 checkedList.setId("checkedList1"); //チェックボックス表示タグID指定 checkedList.setItemText(itemTextArray); //チェックボックスへ表示テキスト割り当て checkedList.setItemImage(itemImageArray); //チェックボックスへ表示画像割り当て checkedList.setItemCount(4); //チェックボックス表示項目数指定
コード5(1/2)
330 330 330
checkedList.refresh(); //チェックボックス表示 </script> </body> </html>
コード5(2/2)
331 331 331
6 ラジオボタン
<html> <head> <title>ActiveWidgets Examples</title> <script src="../awidgets/runtime/lib/aw.js"></script> <link href="../awidgets/runtime/styles/xp/aw.css" rel="stylesheet"/> </head> <body> <p id="radio1"></p> <script> var itemTextArray = ["Home", "Favorites", "Font size", "Search"]; //ラジオボタン表示テキスト指定 var itemImageArray = ["home", "favorites", "fontsize", "search"]; //ラジオボタン表示画像指定 var radio = new AW.UI.Radio; //ラジオボタンインスタンス生成 radio.setId("radio1"); //ラジオボタン表示タグID指定 radio.setItemText(itemTextArray); //ラジオボタンへ表示テキスト割り当て radio.setItemImage(itemImageArray); //ラジオボタンへ表示画像割り当て radio.setItemCount(4); //ラジオボタン表示数指定
コード6(1/2)
332 332 332
radio.setSelectedItems([0]); //初期選択をトップボタン(Home)に指定 radio.refresh(); //ラジオボタン表示 </script> </body> </html>
コード6(2/2)
333 333 333
7 リスト
<html> <head> <title>ActiveWidgets Examples</title> <script src="../awidgets/runtime/lib/aw.js"></script> <link href="../awidgets/runtime/styles/xp/aw.css" rel="stylesheet"/> </head> <body> <p id="list1"></p> <script> var itemTextArray = ["Home", "Favorites", "Font size", "Search"]; //リスト表示テキスト指定 var itemImageArray = ["home", "favorites", "fontsize", "search"]; //リスト表示画像指定 var list = new AW.UI.List; //リストインスタンス生成 list.setId("list1"); //リスト表示タグID指定 list.setItemText(itemTextArray); //リストへ表示テキスト割り当て list.setItemImage(itemImageArray); //リストへ表示画像割り当て
コード7(1/2)
334 334 334
list.setItemCount(4); //リスト表示項目数指定 list.refresh(); //リスト表示 </script> </body> </html>
コード7(2/2)
335 335 335
8 グループ
<html> <head> <title>ActiveWidgets Examples</title> <script src="./runtime/lib/aw.js"></script> <link href="./runtime/styles/xp/aw.css" rel="stylesheet"/> <style>#group1 {width: 300px; height: 50px}</style> </head> <body> <p id="group1"></p> <script> var group = new AW.UI.Group; //グループインスタンス生成 group.setId("group1"); //グループ表示タグID指定 group.setControlText("Group/Fieldset"); //グループ枠表示テキスト指定 group.setControlImage("favorites"); //グループ枠表示画像(星印)指定 group.refresh(); //グループ表示 </script> </body> </html>
コード8
336 336 336
9 インプット
<html> <head> <title>ActiveWidgets Examples</title> <script src="../awidgets/runtime/lib/aw.js"></script> <link href="../awidgets/runtime/styles/xp/aw.css" rel="stylesheet"/> </head> <body> <p id="input1"></p> <script> var input = new AW.UI.Input; //インプットインスタンス生成 input.setId("input1"); //インプット表示タグID指定 input.setControlText("Input"); //初期表示テキスト指定 input.setControlImage("search"); //表示画像指定 input.refresh(); //インンプット表示 </script> </body> </html>
コード9
337 337 337
10 ボタン
<html> <head> <title>ActiveWidgets Examples</title> <script src="./runtime/lib/aw.js"></script> <link href="./runtime/styles/xp/aw.css" rel="stylesheet"/> </head> <body> <p id="button1"></p> <script> var button = new AW.UI.Button; //ボタンインスタンス生成 button.setId("button1"); //ボタン表示タグID指定 button.setControlText("Button"); //ボタン表示テキスト指定 button.setControlImage("favorites"); //ボタン表示画像指定」 button.refresh(); //ボタン表示 </script> </body> </html>
コード10
338 338 338
11 リンク
<html> <head> <title>ActiveWidgets Examples</title> <script src="../awidgets/runtime/lib/aw.js"></script> <link href="../awidgets/runtime/styles/xp/aw.css" rel="stylesheet"/> </head> <body> <p id="link1"></p> <script> var link = new AW.UI.Link; //リンクインスタンス指定 link.setId("link1"); //リンク表示タグID指定 link.setControlText("Hyperlink"); //リンクテキスト指定 link.setControlImage("home"); //リンク表示画像指定 link.setControlLink("http://www.google.com"); //リンクへのURL割り当て link.refresh(); //リンク表示 </script> </body> </html>
コード11
Enterprise2.0
340 340 340
script.aculo.us (スクリプタキュラス)
http://script.aculo.us/ Web画面にエフェクト効果を 与えるJavaScriptライブラリ ・Ajaxコンロトロール ・アニメーション ・ドラッグ&ドロップ ・DOMユーティリティ ・ユニットテスト ・MIT License
341 341 341
Appear 出現させる
書式 new Effect.Appear(element, option) element.visualEffect("Appear", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
エフェクト(Effect)
342 342 342
Appearサンプル ボタンクリックで出現させる
343 343 343
BlindDown 内容を上から下に出現させる 書式 new Effect.BlindDown(element, option) element.visualEffect("BlindDown", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
344 344 344
BlidDownサンプル 水色ボックス内クリックでブラインドダウン
345 345 345
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>BlindDown</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:320; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function BlindUp(){ //new Effect.BlindUp("area"); $("area").visualEffect("BlindDown"); } function listeners(){ addListener($("area"), "click", BlindUp, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2>BlindDownサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
blindup.htm
346 346 346
BlindUp 内容を下から上に消す
書式 new Effect.BlindUp(element, option) element.visualEffect("BlindUp", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
347 347 347
BlidUpサンプル 水色ボックス内クリックでブラインドアップ
348 348 348
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>BlindUp</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:480; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function BlindUp(){ //new Effect.BlindUp("area"); $("area").visualEffect("BlindUp"); } function listeners(){ var eSrc = $("area"); addListener(eSrc, "click", BlindUp, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2>BlindUpサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
blindup.htm
349 349 349
DropOut 落下させて消す
書式 new Effect.DropOut(element, option) element.visualEffect("DropOut", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
350 350 350
DropOut 水色ボックス内クリックでドロップアウト
351 351 351
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>DropOut</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:500; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function DropOut(){ $("area").visualEffect("DropOut"); //$("area").visualEffect("DropOut", {transition: Effect.Transitions.linear}); //$("area").visualEffect("DropOut", {transition: Effect.Transitions.reverse}); //$("area").visualEffect("DropOut", {transition: Effect.Transitions.flicker}); //$("area").visualEffect("DropOut", {transition: Effect.Transitions.wobble}); //$("area").visualEffect("DropOut", {transition: Effect.Transitions.pulse}); //$("area").visualEffect("DropOut", {transition: Effect.Transitions.none}); //$("area").visualEffect("DropOut", {transition: Effect.Transitions.full}); } function listeners(){ var eSrc = $("area"); addListener(eSrc, "click", DropOut, false); } addListener(self, "load", listeners, false); //]]> </script>
dropout.htm
352 352 352
Fade フェード(消滅)させる
書式 new Effect.Fade(element, option ) element.visualEffect("Fade", option ) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
DropOut 水色ボックス内クリックでフェードアウト
354 354 354
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Fade</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:500; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Fade(){ //new Effect.BlindUp("area"); $("area").visualEffect("Fade", {transition: Effect.Transitions.linear}); } function listeners(){ var eSrc = $("area"); addListener(eSrc, "click", Fade, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2>Fadeサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
dropout.htm
355 355 355
Fold 縦、横の順で折り畳んで消す
書式 new Effect.Fold(element, option) element.visualEffect("Fold", option) ] element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
DropOut 水色ボックス内クリックでホールド
357 357 357
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Fade</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:500; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Fold(){ //new Effect.BlindUp("area"); $("area").visualEffect("Fold", {transition: Effect.Transitions.linear}); } function listeners(){ var eSrc = $("area"); addListener(eSrc, "click", Fold, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2>Foldサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
fold.htm
358 358 358
Grow 拡大しながら出現させる
書式 new Effect.Grow(element, option) element.visualEffect("Grow", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
359 359 359
Growサンプル
360 360 360
<style type="text/css"> <!-- #area {width:400; height:130px; background:#eef; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Grow(){ var node = document.getElementsByTagName("p").item(0); for(var i = 5 ; i < 10; i++){ var div = document.createElement("div"); div.style.fontSize = "30px"; div.style.color = "#e02"; var text = document.createTextNode("Ajax World 200" + i); div.appendChild(text); node.appendChild(div); } node.setAttribute("id","area"); $("area").visualEffect("Grow", {transition: Effect.Transitions.linear}); } function listeners(){ var eSrc = $("exe"); addListener(eSrc, "click", Grow, false); } addListener(self, "load", listeners, false); //]]> </script>
grow.htm
361 361 361
Highlight ハイライトさせる
書式 new Effect.Highlight(element, option) element.visualEffect("Highlight", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
362 362 362
Highlightサンプル
363 363 363
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>HighLight</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area {width:210px; height:100px; background:#ddf; font-size:40px; font-weight:700; color: #d03; } --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function HighLight(){ var text = document.createTextNode("Ajax World"); var node = document.getElementsByTagName("div").item(0); node.appendChild(text); node.setAttribute("id","area"); new Effect.Highlight("area", {transition:Effect.Transitions.pulse}); } function listeners(){ addListener($("exe"), "click", HighLight, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body>
highlight.htm
364 364 364
MoveBy 移動させる
書式 new Effect.MoveBy(element, dy, dx, option) element.visualEffect("MoveBy", dy, dx, option) element : ページ上のエレメント dx : 横方向の移動量(相対) dy : 縦方向の移動量(相対) option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
365 365 365
MobeByサンプル
366 366 366
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>MoveBy</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:125px; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function MoveBy(){ new Effect.MoveBy("area", 50, 500 , {transition: Effect.Transitions.pulse} ); //$("area").visualEffect("MoveBy", 50, 200); } function listeners(){ addListener($("exe"), "click", MoveBy, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">MoveByサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
moveby.htm
367 367 367
Opacity 不透明度を変化させる
書式 new Effect.Opacity(element, option) element.visualEffect("Opacity", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
368 368 368
Opacityサンプル
369 369 369
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Opacity</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:125px; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Opacity(){ new Effect.Opacity("area", {from: 0.1 , to: 0.7}); //$("area").visualEffect("Opacity", 0.1, 0.7); } function listeners(){ addListener($("exe"), "click", Opacity, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">Opacityサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
opacity.htm
370 370 370
Puff 拡大して消滅させる
書式 new Effect.Puff(element, option) element.visualEffect("Puff", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
371 371 371
Puffサンプル
372 372 372
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Puff</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:300px; height:110px; background:#ddf;} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Puff(){ //new Effect.Puff("area"); $("area").visualEffect("Puff"); } function listeners(){ var eSrc = $("exe"); addListener($("exe"), "click", Puff, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">Puffサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
puff.htm
373 373 373
Pulsate 点滅させる 書式 new Effect.Pulsate(element, option) element.visualEffect("Pulsate", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
374 374 374
Pulsateサンプル
375 375 375
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Pulsate</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:300px; height:110px; background:#ccf;} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Pulsate(){ new Effect.Pulsate("area"); //$("area").visualEffect("Pulsate"); } function listeners(){ addListener($("exe"), "click", Pulsate, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">Pulsateサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
pulsate.htm
376 376 376
Scale 指定サイズに拡大縮小する(スケール)
書式 new Effect.Scale(element, scale, option) element.visualEffect("Scale", option) element : ページ上のエレメント scale : 倍率(100が等倍) option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
377 377 377
Scaleサンプル
378 378 378
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Scale</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Scale(){ new Effect.Scale("area", 500); //$("area").visualEffect("Scale"); } function listeners(){ addListener($("exe"), "click", Scale, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">Scaleサンプル</h2> <img id="area" src="fuji.jpg" width="150" height="110"/> </body> </html>
scale.htm
379 379 379
ScrooTo 指定エレメントまでスクロールさせる 書式 new Effect.ScrollTo(element, option) element.visualEffect("ScrollTo", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
380 380 380
ScrooToサンプル
381 381 381
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>ScrollTo</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function ScrollTo(e){ if(getid(e)=="area1") area="area2";else area="area1"; new Effect.ScrollTo(area); } function listeners(){ addListener($("exe"), "click", ScrollTo, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2>ScrollToサンプル</h2> <div id="exe"> <h3 id="area1">山桜へ</h3> <img src="fuji.jpg" width="600" height="440"/> <h3 id="area2">富士へ</h3> <img src="sakura.jpg" width="600" height="440"/> </div> </body> </html>
scrollto.htm
382 382 382
Shake 左右に小刻みに揺らす(シェイク) 書式 new Effect.Shake(element, option) element.visualEffect("Shake", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
383 383 383
Shakeサンプル
384 384 384
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Shake</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Shake(){ new Effect.Shake("area", {duration: 50}); //$("area").visualEffect("Shake"); } function listeners(){ var eSrc = $("exe"); addListener($("exe"), "click", Shake, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">Shakeサンプル</h2> <img id="area" src="fuji.jpg" width="450" height="330"/> </body> </html>
shake.htm
385 385 385
Shrink 縮小させる 書式 new Effect.Shrink(element, option) element.visualEffect("Shrink", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
386 386 386
Shrinkサンプル
387 387 387
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Shrink</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Shrink(){ new Effect.Shrink("area"); //$("area").visualEffect("Shrink"); } function listeners(){ addListener($("exe"), "click", Shrink, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">Shrinkサンプル</h2> <img id="area" src="fuji.jpg" width="750" height="550"/></body> </html>
shrink.htm
388 388 388
SlideDwon 内容を上から下にスライド表示する 書式 new Effect.SlideDown(element, option) element.visualEffect("SlideDown", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
389 389 389
SlideDownサンプル
390 390 390
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>SlideDown</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area {width:500; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function SlideDown(){ new Effect.SlideDown("area"); //$("area").visualEffect("SlideDown"); } function listeners(){ addListener($("exe"), "click", SlideDown, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">SlideDownサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
slidedown.htm
391 391 391
SlideUp 内容を下から上に消す 書式 new Effect.SlideUp(element, option) element.visualEffect("SlideUp", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
392 392 392
SlideUpサンプル
393 393 393
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>SlideUp</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area {width:500; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function SlideUp(){ new Effect.SlideUp("area"); //$("area").visualEffect("SlideUp"); } function listeners(){ addListener($("exe"), "click", SlideUp, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">SlideUpサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
slidedown.htm
394 394 394
Squish 縮小して消滅させる 書式 new Effect.Squish(element, option) element.visualEffect("Squish", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
395 395 395
Squishサンプル
396 396 396
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Squish</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area {width:500; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Squish(){ new Effect.Squish("area"); //$("area").visualEffect("Squish"); } function listeners(){ addListener($("exe"), "click", Squish, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">Squishサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body>
squish.htm
397 397 397
Switchoff 外側から消滅させる 書式 new Effect.SwitchOff(element, option) element.visualEffect("SwitchOff", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
398 398 398
SwitchOffサンプル
399 399 399
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>SwitchOff</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area {width:500; height:125px; background:#ddf; font-size:20px; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function SwitchOff(){ new Effect.SwitchOff("area"); //$("area").visualEffect("SwitchOff"); } function listeners(){ addListener($("exe"), "click", SwitchOff, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">SwitchOffサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
switchoff.htm
400 400 400
[複合エフェクトの実行]
Parallel 複合エフェクトを実行する
書式 new Effect.Parallel(effect, option) element.visualEffect("Parallel", option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 from : 開始値 to : 終了値 duration : エフェクト開始から終了までの時間 fps : フレームレート delay : エフェクト開始までの時間 transition : 処理の種類 Effect.Transitions.linear Effect.Transitions.sinoidal【デフォルト】 Effect.Transitions.reverse Effect.Transitions.flicker Effect.Transitions.wobble Effect.Transitions.pulse Effect.Transitions.none Effect.Transitions.full
401 401 401
Parallelサンプル1
402 402 402
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Parallel</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:150px; height:150px; background:#ddf; font-size:24px; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Parallel(){ var area = $("area"); new Effect.Parallel([ new Effect.MoveBy("area", 50, 400), new Effect.Scale("area", 0.3), new Effect.Highlight("area") ]); } function listeners(){ addListener($("exe"), "click", Parallel, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">Parallelサンプル</h2> <div id="area">茨城<br/>千葉<br/>埼玉<br/>東京<br/>神奈川<br/>山梨<br/></div> </body> </html>
parallel1.htm
Parallelサンプル2
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>Parallel</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- #area{width:150px; height:150px; background:#ddf; font-size:24px; font-weight:600} --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js?load=effects"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function Parallel(){ var area = $("area"); new Effect.Parallel([ new Effect.MoveBy("area", 50, 100 , {transition: Effect.Transitions.pulse}), new Effect.Scale("area", 500) //new Effect.BlindUp("area") ]); } function listeners(){ addListener($("exe"), "click", Parallel, false); } addListener(self, "load", listeners, false); //]]> </script> </head> <body> <h2 id="exe">Parallelサンプル</h2> <img id="area" src="fuji.jpg" width="100" height="65" /> </body> </html>
parallel2.htm
405 405 405
ドラッグドロップ
(DragDrop)
406 406 406
Draggable ドラッグ可能なエレメントを指定する 書式 dragObj = new Draggable(element, option) dragObj : ドラッグオブジェクト element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 handle : ハンドル(エレメント名を指定) revert : ドラッグ終了後に元の位置に戻す(true : 戻す、false : 戻さない) snap : スナップ処理 zIndex : Z座標(初期値は10000) constraint : 移動方向制限(horizontal : 水平のみ、vertical : 垂直のみ) ghosting : ドラッグ前のエレメントを表示したままにするかどうか (true : する、false : しない) starteffect : ドラッグ開始時のエフェクト reverteffect : 復帰時のエフェクト endeffect : ドラッグ終了時のエフェクト
407 407 407
Draggableサンプル
408 408 408
<head> <title>script.aculo.us ドラッガブル </title> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <style type="text/css"> <!-- .box1 {width:160px;height:60px;background:#bbf;} #dragbox {font-size:16px; font-weight:600; color:#009} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../../lib/scriptaculous.js"></script> <script type="text/javascript" src="../../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function func1(){ new Draggable('dragbox',{scroll:window}); } addListener(self, "load", func1, false); //]]> </script> </head> <body> <h2>script.aculo.us ドラッガブル</h2> <div id="dragbox" class="box1"> 栃木、群馬、茨城,<br/> 千葉、埼玉、東京、<br/> 神奈川、山梨 </div> </body> </html>
draggable.htm
409 409 409
destory ドラッグオブジェクトを破棄(固定)する
書式 draggableObj.destroy() draggableObj : ドラッガブルオブジェクト
410 410 410
destoryサンプル
1 2
3 4
411 411 411
<style type="text/css"> <!-- .box1 {z-index:1000;width:150px;height:150px;background:#bbf;} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../../lib/scriptaculous.js"></script> <script type="text/javascript" src="../../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ var box; function func1(){ box = new Draggable("box1", {scroll:window,handle:'handle1'}); } function fix(){ box.destroy(); } function listeners(){ addListener($("fix"), "click", fix, false); } addListener(self, "load", listeners, false); addListener(self, "load", func1, false); //]]> </script> </head> <body> <h2>script.aculo.us ドラッグと位置固定</h2> <div id="box1" class="box1"> <span id="handle1">ここをドラッグ</span><br/> <input type="checkbox" id="fix"/> 固定? </div> </body> </html>
destory.htm
412 412 412
1 2
3 4
return ドラッグオブジェクトを元の位置に戻す
413 413 413
<style type="text/css"> <!-- .box1 {z-index:1000;width:150px;height:150px;background:#bbf;} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../../lib/scriptaculous.js"></script> <script type="text/javascript" src="../../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function func1(){ new Draggable('revertbox1',{ scroll:window,handle:'handle1',revert:function(element){ return ($('shouldrevert1').checked) } }); } addListener(self, "load", func1, false); //]]> </script> </head> <body> <h2>script.aculo.us ドラッグ&ドロップ</h2> <div id="revertbox1" class="box1"> <span id="handle1">ここをドラッグ</span><br/> <input type="checkbox" id="shouldrevert1"/> 戻す? </div> </body> </html>
return.htm
414 414 414
Droppable.add ドロップ可能領域を指定する 書式 Droppables.add(element, option) element : ドロップ領域を示すエレメント option : オプション【省略可能】 accept : ドロップ可能なCSSクラス名 containt : 並べ替え可能を示すエレメント/配列 hoverclass : ドロップ中に適用するスタイルシートクラス overlap : 並べ替え時に使用(horizontalまたはvertical) greedy : 他のドロップ領域を検索しない onHover : ドロップ中の処理 onDrop : ドロップされた時の処理
415 415 415
Droppableサンプル
416 416 416
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>script.aculo.us ドラッグ&ドロップ</title> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <style type="text/css"> <!-- #box1 { position:absolute; top:50px; left:10px; z-index:2;width:150px;height:60px;background:#ccf;} #box2 { position:absolute; top:50px; left:170px; z-index:1;width:150px;height:60px;background:#fcc;} #dropBox {position:absolute; top: 200px; left:10px; z-index:0;width:310px;height:180px;background:#cfc;} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../../lib/scriptaculous.js"></script> <script type="text/javascript" src="../../lib/unittest.js"></script>
droppable.htm 1/2
417 417 417
<script type="text/javascript" charset="utf-8"> //<![CDATA[ //var dragObj; function func1(){ new Draggable("box1", { revert:true } ); new Draggable("box2", { revert:true } ); Droppables.add("dropBox", { onDrop: function(element, droppableElement){ $(droppableElement).innerHTML += "<br/>" + element.id + "がドロップされました"; }, accept:"out" }); } addListener(self, "load", func1, false); //]]> </script> </head> <body> <h2>script.aculo.us ドロップエリア設定</h2> <div id="box1" class="out">box1:<br/>ドロップできます</div> <div id="box2">box2:<br/>ドロップできません</div> <div id="dropBox">ドロップゾーン:</div> </body> </html>
droppable.htm 1/2
418 418 418
Droppableサンプル2
419 419 419
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>script.aculo.us ドラッグ&ドロップ</title> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <style type="text/css"> <!-- #book1 { position:absolute; top:50px; left:10px; z-index:2;width:130px;height:130px;} #book2 { position:absolute; top:50px; left:170px; z-index:1;width:130px;height:130px;} #basket {position:absolute; top: 220px; left:10px; z-index:0;width:290px;height:170px;background:#cfc;} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../../lib/scriptaculous.js"></script> <script type="text/javascript" src="../../lib/unittest.js"></script>
droppable 2.htm 1/2
420 420 420
<script type="text/javascript" charset="utf-8"> //<![CDATA[ function func1(){ new Draggable("book1", { revert:true } ); new Draggable("book2", { revert:true } ); Droppables.add("basket", { onDrop: function(element, droppableElement){ $(droppableElement).innerHTML += "<br/>" + element.id + "がカゴに入りました。"; }, accept:"out1" }); } addListener(self, "load", func1, false); //]]> </script> </head> <body> <h2>script.aculo.us ドロップエリア設定</h2> <div id="book1" class="out1"> <img id="area" src="../img/ajaxbook1.jpg" width="130" height="130"/> </div> <div id="book2" class="out2"> <img id="area" src="../img/ajaxbook2.jpg" width="130" height="130"/> </div> <div id="basket">買いものカゴ:</div> </body> </html>
droppable 2.htm 2/2
421 421 421
removeサンプル
Droppable.remove ドロップ可能領域を解除する 書式 Droppables.remove(element)
422 422 422
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>script.aculo.us ドラッグ&ドロップ</title> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <style type="text/css"> <!-- #book1 { position:absolute; top:100px; left:10px; z-index:2;width:130px;height:130px;} #book2 { position:absolute; top:100px; left:170px; z-index:1;width:130px;height:130px;} #basket {position:absolute; top: 270px; left:10px; z-index:0;width:290px;height:170px;background:#cfc;} --> </style> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../../lib/scriptaculous.js"></script> <script type="text/javascript" src="../../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8">
remove.htm 1/2
423 423 423
<script type="text/javascript" charset="utf-8"> //<![CDATA[ function func1(){ new Draggable("book1", { revert:true } ); new Draggable("book2", { revert:true } ); Droppables.add("basket", { onDrop: function(element, droppableElement){ $(droppableElement).innerHTML += "<br/>" + element.id + "がカゴに入りました。"; }, accept:"out1"}); } function remove1(){ Droppables.remove("basket"); } function listeners(){ addListener($("exe"), "click", remove1, false); } addListener(self, "load", listeners, false); addListener(self, "load", func1, false); //]]> </script> </head> <body> <h2>script.aculo.us ドロップエリア解除</h2> <input type="button" id="exe" value="解除"/> <div id="book1" class="out1"> <img id="area" src="../img/ajaxbook1.jpg" width="130" height="130"/> </div> <div id="book2" class="out2"> <img id="area" src="../img/ajaxbook2.jpg" width="130" height="130"/> </div> <div id="basket">買いものカゴ:</div> </body> </html>
remove.htm 2/2
買物籠と購入合計金額表示追加
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>script.aculo.us ドラッグ&ドロップ</title> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <style type="text/css"> <!-- #book1 { position:absolute; top:50px; left:5px; z-index:1;width:130px;height:130px;} #book2 { position:absolute; top:50px; left:135px; z-index:1;width:130px;height:130px;} #book3 { position:absolute; top:50px; left:265px; z-index:1;width:130px;height:130px;} #amount1 {position:absolute; top: 205px; left:150px; z-index:0;width:130px; height:20px;background:#eee;} #amount2 {position:absolute; top: 205px; left:280px; z-index:0;width:90px; height:20px;background:#eee;} #basket {position:absolute; top: 230px; left:10px; z-index:0;width:370px;height:160px;background:#cfc;} --> </style>
droppable3.htm (1/3)
<script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../../lib/scriptaculous.js"></script> <script type="text/javascript" src="../../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ var amount = 0; function func1(){ new Draggable("book1", { revert:true }); new Draggable("book2", { revert:true }); new Draggable("book3", { revert:true }); Droppables.add("basket", { onDrop: function(element, droppableElement){ $(droppableElement).innerHTML += "<br/>" + element.id + "がカゴに入りました。"; if(element.id == "book1"){ amount += 3050; }else if(element.id == "book2"){ amount += 2100; }else if(element.id == "book3"){ amount += 4200; } $("amount2").innerHTML = amount; }, accept:"out" }); }
droppable3.htm (2/3)
addListener(self, "load", func1, false); //]]> </script> </head> <body> <h2>script.aculo.us ドロップエリア設定</h2> <div id="book1" class="out"> <img src="../img/ajaxbook1.jpg" width="130" height="130"/> </div> <div id="book2" class="out"> <img src="../img/ajaxbook2.jpg" width="130" height="130"/> </div> <div id="book3" class="out"> <img src="../img/csbook1.jpg" width="130" height="130"/> </div> <div id="amount1">購入合計金(円):</div><div id="amount2"></div> <div id="basket">買いものカゴ:</div> </body> </html>
droppable3.htm (3/3)
428 428 428
スライダデモ
スライダ(Slider)
429 429 429
Control.Slider スライダーコントロールを設定する 書式 sliderObj = new Control.Slider(handle, track, options) sliderObj : スライダーオブジェクト handle : スライダーハンドル(可動部分) track : スライダートラック(可動範囲部分) options : オプション【省略可能】 axis : スライダー可動方向 increment : 1ピクセルに対して加算する値 maximum : 最大値 minimum : 最小値 range : スライダー値の範囲 alignX : 横(右)の余白 alignY : 縦(下)の余白 sliderValue : 初期値 disabled : スライダーのロック handleImage : ハンドル画像 handleDisabled : 無効の場合のハンドル画像 values : スライダーが取る値(配列で指定)
430 430 430
sliderObj = new Control.Slider(handle, track, options) ・最初のパラメータにはスライダーのハンドル(ドラッグして動かす部分) を指定。 ・2番目のパラメータにはトラック(スライダーの可動範囲)のエレメント を指定。 ・3番目のオプションでスライダーの各種設定を行う。 ※スライダー値の範囲を指定するにはrange:$R(0,100)のように指定。
431 431 431
Sliderサンプル 標準水平スライダ
432 432 432
<style type="text/css"> <!-- #track { width:200px;background-color:#888;} #handle {width:5px; height:10px; background-color:#fc3; cursor:move;} #value { padding-top: 5px;} --> </style> <script src="../../lib/funcs.js" type="text/javascript"></script> <script src="../lib/prototype.js" type="text/javascript"></script> <script src="../lib/scriptaculous.js" type="text/javascript"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function slider(){ new Control.Slider('handle','track',{ onSlide:function(v){$('value').innerHTML='スライド: '+v}, onChange:function(v){$('value').innerHTML='変更値 '+v} }); } addListener(self, "load", slider, false); //]]> </script> </head> <body> <h3>標準水平スライダ</h3> <div id="track"> <div id="handle"></div> </div> <div id="value"></div> </body> </html>
slider1.htm
433 433 433
Sliderサンプル 標準垂直スライダ
434 434 434
<style type="text/css"> <!-- #track { height:120px;background-color:#888; width:12px;} #handle {width:12px; background-color:#fc3;cursor:move;} --> </style> <script src="../../lib/funcs.js" type="text/javascript"></script> <script src="../lib/prototype.js" type="text/javascript"></script> <script src="../lib/scriptaculous.js" type="text/javascript"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function slider(){ new Control.Slider('handle','track',{ axis:'vertical', onSlide:function(v){$('value').innerHTML='スライド: '+v}, onChange:function(v){$('value').innerHTML='変更値 '+v} }); } addListener(self, "load", slider, false); //]]> </script> </head> <body> <h3>標準垂直スライダ</h3> <div id="track"> <div id="handle"></div> </div> <div id="value"></div> </body> </html>
slider2.htm
435 435 435
Sliderサンプル 逆垂直スライダ
436 436 436
<style type="text/css"> <!-- #track { height:120px;background-color:#888;width:12px;} #handle {width:12px;background-color:#fc3;cursor:move; } --> </style> <script src="../../lib/funcs.js" type="text/javascript"></script> <script src="../lib/prototype.js" type="text/javascript"></script> <script src="../lib/scriptaculous.js" type="text/javascript"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function slider(){ new Control.Slider('handle','track',{axis:'vertical', onSlide:function(v){$('value').innerHTML='スライド: ' + (1-v)}, onChange:function(v){$('value').innerHTML='変更値 '+ (1-v)} }); } addListener(self, "load", slider, false); //]]> </script> </head> <body> <h3>逆垂直スライダ</h3> <div id="track"> <div id="handle"></div> </div> <div id="value"></div> </body> </html>
slider3.htm
437 437 437
Sliderサンプル 断続値スライダ
438 438 438
<style type="text/css"> <!-- #track { width:200px;background-color:#888;} #handle {width:8px; height:10px; background-color:#fc3; cursor:move;} --> </style> <script src="../../lib/funcs.js" type="text/javascript"></script> <script src="../lib/prototype.js" type="text/javascript"></script> <script src="../lib/scriptaculous.js" type="text/javascript"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function slider(){ new Control.Slider('handle','track',{ range:$R(0,200),values:[0,50,100,150,200], onSlide:function(v){$('value').innerHTML='スライド: '+v}, onChange:function(v){$('value').innerHTML='変更値 '+v} }); } addListener(self, "load", slider, false); //]]> </script> </head> <body> <h3>断続値スライダ [0,50,100,150,200]</h3> <div id="track"> <div id="handle"></div> </div> <div id="value"></div> </body> </html>
slider4.htm
439 439 439
Sliderサンプル 自然数連続値スライダ
440 440 440
<style type="text/css"> <!-- #track { width:200px;background-color:#888;} #handle {width:8px; height:10px; background-color:#fc3; cursor:move;} #status {background-color: #DCDCDC; width: 0px; height: 7px; border: #232323 1px dashed; margin-top: 10px;} --> </style> <script src="../../lib/funcs.js" type="text/javascript"></script> <script src="../lib/prototype.js" type="text/javascript"></script> <script src="../lib/scriptaculous.js" type="text/javascript"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function slider(){ new Control.Slider('handle','track',{range:$R(0,20), values:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20], onSlide:function(v){$('value').innerHTML='スライド: '+v; $('status').style.width=(v*3)+'px';}, onChange:function(v){$('value').innerHTML='変更値 '+v} }); } addListener(self, "load", slider, false); //]]> </script> </head> <body> <h3>自然数連続値スライダ </br> [0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20]</br> および値のdivエリア表示</h3> <div id="track"> <div id="handle"></div> </div> <div id="status"></div> <div id="value"></div> </body> </html>
slider5.htm
441 441 441
Sortable エレメントのソート処理を指定する
書式 Sortable.create(element, option) element : ページ上のエレメント option : 以下のオプションを指定可能【省略可能】 tag : ソート対象タグ名 only : 指定されたスタイルシートが適用された項目のみソート対象 overlap : 方向(horizontalまたはvertical) constraint : 移動方向制限(horizontal : 水平のみ、vertical : 垂直のみ) containment : handle : ハンドル(エレメント名を指定) hoverclass : 重なった場合のスタイルシートクラス名 ghosting : ドラッグ前のエレメントを表示したままにするかどうか (true : する、false : しない) dropOnEmpty : scroll : scrollSensitivity : scrollSpeed : スクロール速度 tree : 子ノードもソート対象にするか(true : する、false : しない) treeTag : ソート対象を内包するコンテナのタグ名 onChange : ソートされ順序が変更された時の処理 onUpdate : ソートされ順序が変更された後の処理
ソート(Sortable)
442 442 442
Sortableサンプル-1
Sortableサンプル-1 :FireBugでのDOMツリー変化確認
444 444 444
<style type="text/css" media="screen"> <!-- #list { padding: 2px; background:red;} #list li { background: #ffb; margin:2px; padding: 2px; } .area {width:350px;height:300px;overflow:scroll; position:relative;" id="scroll-container"; } --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js"></script> <script type="text/javascript" src="../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function sorta(){ Position.includeScrollOffsets = true; Sortable.create('list',{scroll:'scroll-container'}); } addListener(self, "load", sorta, false); //]]> </script> </head> <body> <h2>script.aculo.us ソータブル</h2> <div class="area"> <ul id="list"> <li>北海道</li><li>青森</li><li>秋田</li><li>岩手</li><li>山形</li> <li>宮城</li><li>福島</li><li>栃木</li><li>群馬</li><li>茨城</li> <li>千葉</li><li>埼玉</li><li>東京</li><li>神奈川</li><li>山梨</li> </ul> </div> </body> </html>
sort1.htm
445 445 445
Sortableサンプル-2
446 446 446
<<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <title>script.aculo.us ソータブル</title> <style type="text/css" media="screen"> <!-- #list1 { width:250px; padding: 2px; background:#c03;} #list1 li { background: #ffb; margin:2px; padding: 2px; } #list2 { width:250px; padding: 2px; background:#c03;} #list2 li { background: #ffb; margin:2px; padding: 2px; } #inlist1 { width: 200px; padding: 2px; background:#c03;} #inlist1 li { background: #ffb; margin:2px; padding: 2px; } #inlist2 { width: 200px; padding: 2px; background:#c03;} #inlist2 li { background: #ffb; margin:2px; padding: 2px; } #inlist3 { width: 200px; padding: 2px; background:#c03;} #inlist3 li { background: #ffb; margin:2px; padding: 2px; } --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js"></script> <script type="text/javascript" src="../lib/unittest.js"></script>
sort2.htm 1/2
447 447 447
<script type="text/javascript" charset="utf-8"> //<![CDATA[ function sorta(){ Sortable.create("list1"); Sortable.create("list2", { tree:true }); } addListener(self, "load", sorta, false); //]]> </script> </head> <body> <h2>script.aculo.us ソータブル</h2> <ul id="list1"> <li>総面積</li> <li>総人口</li> <li>GNP</li> </ul> <ul id="list2"> <li>北関東<ul id="inlist1"><li>群馬</li><li>栃木</li><li>茨城</li></ul></li> <li>東京都<ul id="inlist2"><li>東京北部</li><li>東京南部</li></ul></li> <li>東京近県<ul id="inlist3"><li>埼玉</li><li>千葉</li><li>神奈川</li></ul></li> </ul> </body> </html>
soer2.htm 2/2
448 448 448
Sortableサンプル-1
449 449 449
<style type="text/css" media="screen"> <!-- #list1 { width:250px; padding: 2px; background:#c03;} #list1 li { background: #ffb; margin:2px; padding: 2px; } --> </style> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js"></script> <script type="text/javascript" src="../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function sorte(){ Sortable.create("list1"); } function sortd(){ Sortable.destroy("list1"); } function listeners(){ addListener($("sortd"), "click", sortd, false); } addListener(self, "load", listeners, false); addListener(self, "load", sorte, false); //]]> </script> </head> <body> <h2>script.aculo.us ソータブル</h2> <input type="button" id="sortd" value="ソート停止"/> <ul id="list1"> <li>群馬</li><li>栃木</li><li>茨城</li><li>埼玉</li> <li>東京</li><li>千葉</li><li>神奈川</li> </ul> </body> </html>
sort3.htm
ソート&ドロップ (dragsort1.htm)
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <title>script.aculo.us ドラッグ&ドロップ</title> <meta http-equiv="content-type" content="text/html; charset=utf-8" /> <style type="text/css"> <!-- #box1 { z-index:2;width:150px;height:40px;background:#00f;} #box2 { z-index:2;width:150px;height:40px;background:#f00;} #box3 { z-index:2;width:150px;height:40px;background:#080;} #box4 { z-index:2;width:150px;height:40px;background:#ff0;} #box5 { z-index:2;width:150px;height:40px;background:#0f0;} #box6 { z-index:2;width:150px;height:40px;background:#880;} #dropBox {position:absolute; top: 320px; left:10px; z-index:0;width:250px; height:120px;background:#ccc;} --> </style>
dragsort1.htm (1/3)
<script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/aculo/prototype.js"></script> <script type="text/javascript" src="../lib/aculo/scriptaculous.js"></script> <script type="text/javascript" src="../lib/aculo/unittest.js"></script> <script type="text/javascript"> //<![DATA[ function loadFunc(){ Sortable.create("sortList"); new Draggable("box1", { revert:true }); new Draggable("box2", { revert:true }); new Draggable("box3", { revert:true }); new Draggable("box4", { revert:true }); new Draggable("box5", { revert:true }); new Draggable("box6", { revert:true }); Droppables.add("dropBox", { onDrop: function(elm, dElm){ $(dElm).innerHTML += "<br/>" + elm.id + "をドロップ"; }, accept:"out" }); } addListener(self, "load", loadFunc, false); //]]> </script>
dragsort1.htm (2/3)
</head> <body> <h2>ソート&ドロップ</h2> <ul id="sortList"> <li class="out" id="box1">項目1</li> <li class="out" id="box2">項目2</li> <li class="out" id="box3">項目3</li> <li class="out" id="box4">項目4</li> <li class="out" id="box5">項目5</li> <li class="out" id="box6">項目6</li> </ul> <div id="dropBox">ドロップゾーン:</div> </body> </html>
dragsort1.htm (3/3)
454 454 454
Ajax.InPlaceCollectionEditor
処理を編集可能なテキストを設定する (セレクトメニューで選択) 書式 editObj = new Ajax.InPlaceCollectionEditor(elementName, url, options) editObj : 編集可能テキストオブジェクト element : フォーム上のエレメント url : CGI等のURL options : オプション【省略可能】 collection : メニューに表示する項目リスト(配列) ・最初のパラメータにはフォーム上のエレメントを指定。 ・2番目のパラメータはURLでデータを(DB等に)保存し、結果を返すための CGIプログラム等を指定。 ・3番目のパラメータはオプションで各種指定を行う。
インプレースエディタ (InPlaceEditor)
455 455 455
InPlaceCollectionEditor-1
456 456 456
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <title>script.aculo.us インプレースエディタ</title> <script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js"></script> <script type="text/javascript" src="../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ function edit(){ new Ajax.InPlaceEditor("value", "edit1.php",{ okText : "保存", cancelText : "キャンセル", savingText : "保存中です...", rows:1, cols:50, onFailure : function(){ alert("保存中にエラー発生"); } }); } addListener(self, "load", edit, false); //]]> </script> </head> <body> <h2>script.aculou エディタ機能</h2> <div id="value">Ajax/Web2.0ワールドの開催日は9月12日です。</div> </body> </html>
editor1.htm
非同期通信との組み合わせ
<?xml version="1.0" encoding="utf-8" standalone="no"?> <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8"> <head> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <title>script.aculo.us インプレースエディタ</title> <script type="text/javascript" src="../../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js"></script> <script type="text/javascript" src="../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> : </script> </head> <body> <h2>script.aculo.us エディタ機能</h2> <div id="value"></div> </body> </html>
editor1.htm (1/2)
//<![CDATA[ function edit(){ $("value").innerHTML = getsyn("init1.php"); new Ajax.InPlaceEditor("value", "edit1.php",{ okText : "保存", cancelText : "キャンセル", savingText : "保存中です...", rows:1, cols:50, onFailure : function(){ alert("保存中にエラー発生"); } }); } addListener(self, "load", edit, false); //]]>
editor1.htm (1/2)
<?php $server = "localhost"; $dbname = "ajax_ec"; $user = "mysql"; $passwd = "callback"; $sv = mysql_connect($server, $user, $passwd) or die("Connection error1"); $db = mysql_select_db($dbname) or die("Connection error2"); $sql = "select * from edit1 order by date desc limit 0,1"; $rows = mysql_query($sql, $sv) or die("mysql query Error"); $row = mysql_fetch_array($rows, MYSQL_ASSOC); if($row > 0){ echo $row["value"]; }else{ echo "NO"; } ?>
init1.php
<?php $value = $_POST["value"]; $server = "localhost"; $dbname = "ajax_ec"; $user = "mysql"; $passwd = "callback"; $sv = mysql_connect($server, $user, $passwd) or die("Connection error1"); $db = mysql_select_db($dbname) or die("Connection error2"); $date = date("Y-n-d"); $sql = "insert into edit1 values('$value', '$date')"; if($rows = mysql_query($sql, $sv)){ echo "編集成功: ".$value; }else{ echo "編集失敗: ".$value; } ?>
edit1.php
461 461 461
InPlaceCollectionEditorサンプル-2
462 462 462
<script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js"></script> <script type="text/javascript" src="../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ var edit1; function edit(){ edit1 = new Ajax.InPlaceEditor("value", "edit1.php",{ okText : "保存", cancelText : "キャンセル", savingText : "保存中です...", rows:1, cols:50, onFailure : function(){ alert("保存中にエラー発生"); } }); } function dispose(){ edit1.dispose(); } function listeners(){ addListener($("dispose"), "click", dispose, false); } addListener(self, "load", listeners, false); addListener(self, "load", edit, false); //]]> </script> </head> <body> <h2>script.aculou エディタ機能</h2> <input type="button" id="dispose" value="編集解除"> <div id="value">Ajax/Web2.0ワールドの開催日は9月12日です。</div> </body> </html>
editor2.htm
463 463 463
InPlaceCollectionEditorサンプル-3
464 464 464
<script type="text/javascript" src="../lib/funcs.js"></script> <script type="text/javascript" src="../lib/prototype.js"></script> <script type="text/javascript" src="../lib/scriptaculous.js"></script> <script type="text/javascript" src="../lib/unittest.js"></script> <script type="text/javascript" charset="utf-8"> //<![CDATA[ var edit1; function edit(){ edit1 = new Ajax.InPlaceEditor("value", "edit1.php", {rows:1, cols:50, okText: "保存" }); } function editmode(){ edit1.enterEditMode("click"); } function dispose(){ edit1.dispose(); } function listeners(){ addListener($("editmode"), "click", editmode, false); addListener($("dispose"), "click", dispose, false); } addListener(self, "load", listeners, false); addListener(self, "load", edit, false); //]]> </script> </head> <body> <h2>script.aculou エディタ機能</h2> <input type="button" id="editmode" value="編集開始"> <input type="button" id="dispose" value="編集解除"> <div id="value">Ajax/Web2.0ワールドの開催日は9月12日です。</div> </body> </html>
editor3.htm