Recommended
PPTX
An other world awaits you
PDF
unique_ptrにポインタ以外のものを持たせるとき
PDF
Android Lecture #03 @PRO&BSC Inc.
PDF
PDF
PDF
PPTX
PPT
[A 3]SSJSでも使える!Javascriptでオブジェクト指向プログラミング入門
PPTX
PDF
PDF
Async design with Unity3D
PDF
PDF
Frege, What a Non-strict Language
PDF
PPTX
PPTX
C# 式木 (Expression Tree) ~ LINQをより深く理解するために ~
PPTX
CakePHP+Smartyハイブリッドによるラクラク開発
PPTX
LINQ 概要 + 結構便利な LINQ to XML
PDF
ODP
PPTX
PDF
PDF
PDF
Java SE 7 InvokeDynamic in JRuby
PDF
PPTX
C#を始めたばかりの人へのLINQ to Objects
PDF
KEY
PDF
ネットワークエンジニアはどこでウデマエをみがくのか?
PDF
More Related Content
PPTX
An other world awaits you
PDF
unique_ptrにポインタ以外のものを持たせるとき
PDF
Android Lecture #03 @PRO&BSC Inc.
PDF
PDF
PDF
PPTX
PPT
[A 3]SSJSでも使える!Javascriptでオブジェクト指向プログラミング入門
What's hot
PPTX
PDF
PDF
Async design with Unity3D
PDF
PDF
Frege, What a Non-strict Language
PDF
PPTX
PPTX
C# 式木 (Expression Tree) ~ LINQをより深く理解するために ~
PPTX
CakePHP+Smartyハイブリッドによるラクラク開発
PPTX
LINQ 概要 + 結構便利な LINQ to XML
PDF
ODP
PPTX
PDF
PDF
PDF
Java SE 7 InvokeDynamic in JRuby
PDF
PPTX
C#を始めたばかりの人へのLINQ to Objects
PDF
KEY
Viewers also liked
PDF
ネットワークエンジニアはどこでウデマエをみがくのか?
PDF
PPTX
Haste (Same Language, Multiple Platforms) and Tagless Final Style (Same Synta...
ODP
PDF
ダウンサイジング時代のプロセス改善モデル(OHP)
DOCX
Influencia británica en la decadencia argentina
PDF
Taller expedición de datos OPEN DATA - DANE - Sharecollab - Work&Go
DOCX
Key isi guerrilla handler on akhtar abdul rehman
PPTX
TripDesign.Us presents Eat Play Chill ; #Meghalaya
PDF
Dove Science Academy Audit - a Gulen operated charter school
PDF
Similar to Ajax 応用
PDF
PDF
Pro aspnetmvc3framework chap19
PDF
KEY
PPTX
PDF
PDF
jQuery と MVC で実践する標準志向 Web 開発
PPTX
PPTX
PDF
jQuery Mobile 1.2 最新情報 & Tips
PDF
Windows ストアアプリのつくりかた (JS + HTML + CSS)
PDF
PPTX
PPTX
PDF
PDF
PPT
PDF
PPTX
PDF
Ajax 応用 1. 2. Ajax実践編 Ajaxライブラリ
1.ActiveWidgets
簡単なサンプル
Ajax要素技術の応用 実習-1
1.テーブルの参照・登録・更新・削除 タブコントロール
イベントの伝播、DOMノード操作、DB登録 ツリーコントロール
2.部品構成(任意の構成)の一括表示 コンボボックス
再帰呼出しでの非同期通信 演習-1
GET/同期、prototype.jsの制限 グリッドコントロール
3.Ajaxでのコールバック処理 実習-2
タイマ-での擬似コールバック 演習-2
Ajax コールバック例 (777マッチ) 演習-3
受注情報登録とコールバック表示 2.DWR
(Direct Web Remoting)
DWRの特徴
DWRサンプル
実習-3
DWRプログラミング
演習-4
演習-5
3.Plotr
実習
4.script.aculo.us
演習-6
5.Yahoo! UI Library 2
演習-7
3. 4. 5. 6. AjaxモデルでのWebシステム
(SPI=Single Page Interface)
Webブラウザ
データアクセス
プレゼンテーション DB
GET/POST
Web
UI テキスト
ビジネスロジック XML
Ajaxエンジン
XML
データストア
Webクライアント CGI系プログラム
ユーザPC サーバサイド
7. Ajaxエンジンの機能
Ajaxエンジン
① イベント処理
Web
GUI サーバ
② サーバ通信 ・テキストデータ
・XMLデータ
XHTML+CSS ③ UI表示
・XHTML 画面構成
・CSS 表示制御
④ 表示制御 ⑤ 演算処理
JavaScript
8. 9. 10. GET/非同期-関数名指定での受信処理
<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>
11. 12. POST/非同期
<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>
13. 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>
14. 15. 16. prototype.js http://www.prototypejs.org
・Ajaxフレームワーク
・JavaScript言語機能強化
・メソッド名ショートカット
・DOM操作機能の拡張
・クロスブラウザ対応
・ MIT License MIT License
※MIT License
・このソフトウェアを誰でも無償で無制限に扱うことができる。但し、著作権表示および本許
諾表示を、ソフトウェアのすべての複製または重要な部分に記載しなければならない。
・作者または著作権者は、ソフトウェアに関してなんら責任を負わない。
17. prototype.jsでの通信
revClass1.js(prototype.js:Ajax.Request)
//<![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);
//]]>
18. addClass1.js(prototype: Ajax.Updater) ※出力用の関数指定なし
//<![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);
//]]>
Ajax.RequestとAjax.Updaterの使い分け
・Ajax.Request 受信データのプログラム処理を想定
・Ajax.Updater 受信データの直接表示を想定(container)
19. Ajaxエンジンの機能
Ajaxエンジン
① イベント処理
Web
GUI サーバ
② サーバ通信 ・テキストデータ
・XMLデータ
XHTML+CSS ③ UI表示
・XHTML 画面構成
・CSS 表示制御
④ 表示制御 ⑤ 演算処理
JavaScript
20. DOMイベントモデル
・ターゲット イベント発生
・オブザーバ イベントキャッチ
ルート document
・バブリングフェーズ
イベントの上位伝播
キャプチャフェーズ table ・キャプチャフェーズ
イベントの下位伝播
tbody
オブザーバ
バブリングフェース
イベントキャッチ
tr
td ターゲット
イベント発生
21. 22. イベントターゲットの検出: getid(e)
イベントターゲット(イベント発生ノード) → idタグで識別
IE系ブラウザ e.srcElement
IE以外のブラウザ e.target
getid関数(funcs.js) 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;
}
23. 入力キーコードの検出: getkcode(e)
IE系および新しいFireFox e. keyCode
古いFireFox e.which
getkcode関数(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;
}
}
24. 25. function mbutton(e){
クリックマウスボタンの検出 var click;
mbutton(e) if(!e) var e = window.event;
if (e.which){
・左ボタンクリック → 戻り値(“L”) if(e.which == 1){
click = "L";
・右ボタンクリック → 戻り値(“R”)
}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;
}
26. 移動するマウスポインタ位置の検出
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座標をピクセル値で返す。
27. 28. マウスポインタ位置の検出 mpos2.htm 1/2
<?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;
}
29. mpos2.htm 2/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>
30. mpos2.js //<![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);
//]]>
31. 32. 33. <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
34. //<![CDATA[ selectMenu.js
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);
//]]>
//<![CDATA[
Prototype.js function checkSpec(){
$(“result”).innerText = “選択結果: ” + $F("pc“);
Function listeners(){
setListener($(“pc”), "change", checkSpec);
}
setListener(window, "load", setListeners);
//]]>
35. 36. selectMenu2.htm
1/4 <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>
37. //<![CDATA[
selectMenu2.htm var httpObj = getHttpObject();
2/4 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;
}
}
}
38. function getClass2(){
selectMenu2.htm var class1_code = $("class1List").value;
3/4 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);
}
}
}
39. selectMenu2.htm
4/4
function getClass3(){
alert($("class2List").value);
}
Function listeners(){
setListener($("class1List"), "change", getClass2);
}
setListener(window, "load", listeners);
setListener(window, "load", getClass1);
40. 41. <script type="text/javascript" src="funcs.js"></script> radioBtn.htm
<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>
42. radioBtn.js
//<![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);
//]]>
43. 44. チェックボックス選択確認XHTML checkB.htm
<?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>
45. 46. 47. <link rel="stylesheet" type="text/css" href="style.css" />
checkBox.htm
<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>
48. //<![CDATA[
var optcum = new Array(); checkBox.js
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);
//]]>
49. checkBox.java
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();
}
}
50. Ajaxエンジンの機能
Ajaxエンジン
① イベント処理
Web
GUI サーバ
② サーバ通信 ・テキストデータ
・XMLデータ
XHTML+CSS ③ UI表示
・XHTML 画面構成
・CSS 表示制御
④ 表示制御 ⑤ 演算処理
JavaScript
52. DOMノード操作
(1) DOMノード操作サンプル
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);
}
}
}
}
53. DOMノード操作概要
ノードの種類 ・要素ノード (element node)
・属性ノード (attribute node)
・テキストノード(text node)
例]
<div id=“id1” class=“class1”>DOMノード操作</div>
要素ノード
<div>
属性ノード
id=“id1” class=“class1”
テキストノード
DOMノード操作
54. 1.要素ノードの参照
getElementById
構文] object.getElementById(“id属性値”)
機能] 指定したID名を持つ要素ノードオブジェクトを返す。
引数] id属性値。
返値] オブジェクト。
適用] document
対応] [IE5~][Firefox1~][Safari1~][Opera8~][Netscape6~]
※非常に頻繁に使用されるメソッドで、多くのAjaxライブラリでショートカット
関数が用意されている。
例] document.getElementById(“out1”);
↓
$(“out1”); // Prototype.js, DWR
id(“out”); // funcs.js
55. 56. 57. 58. 59. 子ノードの参照-2
childNodes
構文] object.childNodes
object.childNodes[index]
object.childNodes.length
機能] オブジェクトの子ノードを参照する。
評価値は配列で最初の子ノードは0番になる。
引数] id属性値。
返値] 子ノードオブジェクトの配列
適用] object
対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
60. 子ノードの参照-3
hasChildNodes
構文] object.hasChildNodes()
機能] 子ノードがあるかどうか返す。
子ノードがある場合はtrue、ない場合はfalseを返す。
引数] id属性値。
返値] 真偽値
適用] object
対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
function check() {
if ($("sample").hasChildNodes()) {
alert(“子ノードがあります。”);
} else {
alert(“子ノードがありません。”);
}
}
61. 兄弟ノードの参照
nextSibling
構文] object.nextSibling
機能] オブジェクトの次のノードを参照する。
返値] ノードオブジェクトの参照
適用] 多くのノードオブジェクト
対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
previousSibling
構文] object.previousSibling
機能] オブジェクトの前のノードを参照する。
返値] ノードオブジェクトの参照
適用] 多くのノードオブジェクト
対応] [IE5~][Firefox 1~][Safari 1~][Opera 8~][Netscape 6~]
62. 63. 64. 65. テキストノードの作成
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);
}
66. 67. 68. 69. 子ノードを置き換え
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);
}
70. 71. 72. 73. 74. XMLHttpRequestでのデータ送受信オーバヘッド
イーザネット 12Byte 4
フレーム B
IPデータグラム 24Byte
TCPセグメント 20Byte
HTTPヘッダ
ヘッダデータ量: 60Byte + HTTPプロトコルヘッダ
HTTPプロトコル リクエストヘッダ例 HTTPプロトコル レスポンスヘッダ例
GET /docs/sw/http-header.html HTTP/1.1 HTTP/1.1 200 OK
Host: www.kanzaki.com Date: Wed, 05 Sep 2001 06:06:19 GMT
Accept: text/html, text/plain, text/sgml, */*;q=0.01 Server: Apache/1.3.12
Accept-Encoding: gzip, compress Accept-Language: ja,en Content-Location: http-header.html.ja
If-Modified-Since: Sun, 2 Sep 2001 11:31:06 GMT Vary: negotiate,accept-language,accept-charset
User-Agent: Lynx/2.8.2 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
75. XMLHttpRequestでのデータ送受信オーバヘッド
ヘッダデータ量: 60Byte + HTTPプロトコルヘッダ
HTTPプロトコル リクエストヘッダ例 HTTPプロトコル レスポンスヘッダ例
GET /docs/sw/http-header.html HTTP/1.1 HTTP/1.1 200 OK
Host: www.kanzaki.com Date: Wed, 05 Sep 2001 06:06:19 GMT
Accept: text/html, text/plain, text/sgml, */*;q=0.01 Server: Apache/1.3.12
Accept-Encoding: gzip, compress Accept-Language: ja,en Content-Location: http-header.html.ja
If-Modified-Since: Sun, 2 Sep 2001 11:31:06 GMT Vary: negotiate,accept-language,accept-charset
User-Agent: Lynx/2.8.2 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 75
イーザネット 12Byte 4
フレーム B
IPデータグラム 24Byte
TCPセグメント 20Byte
HTTPヘッダ
76. 77. 言語機能強化
Ajaxライブラリ Prototype.js
MochiKit
エフェクト系
script.aculo.us サーバ ビジネス
Yahoo! UI Library リクエスト ロジック
Plotr
DWR DWR
ActiveWidgets
Dojo [サーバ]
開発者 Yahoo! UI Library
ユーザ ・リモーティングツール
コントロール系
・UIツール
[クライアント] 77
78. Ajaxライブラリ 言語機能強化
Prototype.js
MochiKit
エフェクト系 [リモーティングツール]
script.aculo.us サーバ ビジネス
リクエスト ロジック
Yahoo UI Library
Plotr
DWR DWR
ActiveWidgets
Dojo [サーバ]
開発者 Yahoo UI Library
ユーザ
コントロール系
[UIツール]
[クライアント] 78
79. Ajaxモデルでの処理の流れ
DOM
① イベント処理
サーバリモーティング
Web GET/POST
DOM API サーバ
GUI
② サーバ通信 ・テキストデータ
・XMLデータ
XHTML+CSS ③ UI表示
・XHTML 画面構成
・CSS 表示制御
④ 表示制御 ⑤ 演算処理
言語機能
JavaScript
(Ajaxエンジン)
80. Ajaxモデルとライブラリ
言語機能拡張
① イベント処理
サーバリモーティング
Web GET/POST
UI表現 サーバ
GUI
② サーバ通信 ・テキストデータ
・XMLデータ
XHTML+CSS ③ UI表示
・XHTML 画面構成
・CSS 表示制御
④ 表示制御 ⑤ 演算処理
JavaScript
(Ajaxエンジン)
81. 82. DWR(Direct WebRemoting)
DWR:Easy Ajax for Java
http://getahead.ltd.uk/dwr/
Ajaxアプリケーションを
サーバサイドJavaで開発
するための
JavaScript-Java連携用
フレームワーク
Apache License, Version 2.0
再配布要件
(1)LICENSEファイルを再配布物内の「どこか」に置く。
(2)再配布要件(自分の著作物も含む)は、適度に定めてよい。
付与要件
(1)LICENSEファイルを作る。(Apacheライセンス参照)
(2)LICENSEファイルの中身に
Copyright [yyyy] [著作権所有者の名前]
をつける。(もちろん再配布物と一緒に入れる)
82
83. 84. DWRでのシステム構成
-制御機能(Controller)はシステム(DWR)に任せ、 :ユーザ記述
開発者はビジネスロジック作成に専念できる。
:DWRサポート
[ビュー] [コントローラ] [モデル]
DWR Client DWR Servlet Java Beans DB
Ajax
[プレゼンテーション層] web.xml dwr.xml [ファンクショナル層] [データアクセス層]
[3層C/Sシステム] [MVCモデル]
P: プレゼンテ-ション層 M:Model ビジネスロジック
F: ファンクショナル層 V:View 表示機能
D: データアクセス層 C:Controller 処理制御機能
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)]
設定よりも規約
85
86. (2) DRY(Don’t Repeat Yourself)
[DRY=Don’t Repeat Yourself]同じプログラムコードを重複して記述しない。
・機能単位でのクラス構成とメソッド定義 Java Beans
EX] 受注関係のCRUD処理をクラスに (POJO)
まとめる。
顧客クラス
・カスタマイズはオーバライドで行う。
顧客関係
メソッド DB
(crud)
DWR Client コントローラ
機能 社員クラス
・顧客情報表示 DWR 社員関係
・担当者表示 Servlet メソッド DB
・商品情報表示 (crud)
商品クラス
商品関係
メソッド DB
(crud)
86
87. 3.リバースAjax - DWR 2.0から
サーバ側のJavaからクライアントのJavaScriptに非同期にデータ送信が可能
⇒コールバック、サーバプッシュとも言われる
⇒チャットのような対話型のAjaxアプリケーションが記述しやすくなる。
DWRのリバースAjaxでは3つの方式をサポート
Comet, Polling, Piggyback
87
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サーバへの追加の負荷は全くない。
88
89. 4.UIとサーバ通信の分離
・通信機能 → DWR
・UI機能 → ActiveWidgets, Yahoo UI, Dojo etc
=>分散アプリケーション、分散オブジェクトで一般的な形態
vs] GWT(Google Web Toolkit) は一体型
①イベント処理
サーバ
Web 他コンポーネント
GUI DWR
②サーバ通信
XHTML+CSS ③UI表示
④表示制御 ⑤演算処理
Ajaxエンジン 89
90. 5.DWRサーブレットとユーザサーブレットの混在可
[ビュー] [コントローラ] [モデル]
DWR Client
Ajax
DWR Servlet Java Beans
Servlet
DB
Java Beans
(ユーザ記述)
Ajax Client
ユーザ記述Servletは
web.xml dwr.xml ・web.xmlにDWR-Servletと併記可能
ただし、DWR-Servletの後に記述する。
ユーザ記述JavaBeansは
・dwr.xmlに定義しDWRのDEBUG機能
使用可能
・JavaBeans(POJO)は全く同じ
91. 92. 93. プログラム作成 - DWR実行環境
FedoraCore5
APサーバ データベース
DWR
サーバ Tomcat5 Version 2.0 RC 2
サーブレット Java
サーブレット MySQL
コンテナ Beans
サンプル動作環境
Tomcat 5.xx
ブラウザ
ブラウザ J2EE 5.04
クライアント IE 6.0
MySQL 4.1.11
IE6.0
FF2.0
IE 6.0.2800
FF 2.00.2
WindowXP Pro V2
93
94. 95. 96. 97. 98. 99. 100. 101. $CATALINA_HOME
DWRディレクトリ構成
webapps
dwr2
WEB-INF
web.xml
dwr.xml
lib
classes
erp
hr
lib bbb.class
book4
s5
aaa.htm
102. 1. DWR JAR ファイルのダウンロードと配置
(1) http://getahead.org/dwr/download から dwr.jar ファイルをダウンロード。
(2) $CATALINA_HOME/webapps/[開発DIR]/WEB-INF/lib ディレクトリに配置
※DWRディレクトリ(dwr.warでデプロイ)のlib内ファイルをすべてコピーで可
102
103. 2. デプロイメントディスクリプタ(web.xml)の編集
WEB-INF/web.xml にdwr-invokerの行を追加.
※サーブレットの定義はdwr-invokerだけ。
※DWRディレクトリのweb.xmlをコピーで可 web.xml
<?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>
103
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> 参考] web.xml(オリジナル)
<url-pattern>/dwr/*</url-pattern>
</servlet-mapping>
104
</web-app>
105. 3.サーバコード(JavaBeans:POJO)作成
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
}
} 105
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>
creator=“new” :リクエストの際に、Javaオブジェクトの新しいインスタンス生成
※scope属性 application アプリケーション全体で1つのインスタンス作成
session セッション毎にインスタンス生成
request リクエスト毎にインスタンスを生成
page ページ毎にインスタンスを生成
5.tomcat再起動
106
107. 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) {} DWR記述の代替をビーンズコード内で行う。
return empName;
}
108
}
109. 2.web.xmlにアノテーション適用JavaBeans指定
<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>
110. 6.デバックモードでJavaBeansの機能確認
機能] 利用可能なすべてのJavaBeansをWebページ
上で確認できる。
1.web.xmlにdebug機能の使用を指定
<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>
110
111. 112. 7.クライアントコード作成 dwrGetAsyn.htm 1/2
<?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
}
112
113. dwrGetAsyn.htm 2/2
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>
113
114. [参考]
<allow>
DWRが生成・処理可能なクラス範囲を定義する
<create>
<create creator=“生成方法” class=“JavaBeansクラスの完全修飾名”
[javascript=“オブジェクト名”] [scope=“有効範囲”]
[<auth method=“メソッド名” role=“ロール名” />]
[<exclude method=“呼び出しを禁止するメソッド名” />]
[<include method=“呼び出しを許可するメソッド名” />]
</create>
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は現在テスト段階 114
115. 116. メソッド 機能
$(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で指定された
(id,array,cellfuncs,[options]) 配列データをcellfuncsで指定された関数に従って追加する。
DWRUtil.getText(id) 指定されたID値に対応するテキストを所得する。
DWRUtil.selectRange(id,start,end) IDで指定された入力フィールドのstart ~ end文字目までをテキストを選択
する。
DWRUtil.toDescriptiveString(id,opt) 指定された要素に関する情報をオプション(0~2)に従って表示する。
DWRUtil.useLoadingMessage() 通信中のメッセージを表示するように指定する。
117. 118. リモートオブジェクトのオプション指定
オプション 概要
callback リモートコールが成功した場合の処理
errorHandoler リモートコール処理が失敗した場合の処理
ordered 要求された順番で結果を反映するか
preHook リモートコール直前に行う処理
postHook リモートコール直後に行う処理
timmeout 要求のタイムアウト時間(ミリ秒)
verb HTTPメソッド(GETまたはPOST)
warninghandoler ブラウザによる警告が発生した場合の処理
118
119. 120. 121. <?xml version="1.0" encoding="utf-8" standalone="no"?>
JavaChat.htm <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
1/2 "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);
} 121
122. JavaChat.htm function listeners(){
2/2 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>
122
123. package cback;
import java.util.Collection;
import java.util.LinkedList; JavaChat.java
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); 123
}
124. package cback;
import java.net.MalformedURLException;
import java.net.URL;
import org.directwebremoting.Security; Message.java
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;
} 124
125. 126. 127. (1) サーバコード記述 hrBean.java 1/2
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";
}
}
128. hrBean.java addEmpHdr 2/2
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;
}
}
129. (2) 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="hrBean">
<param name="class" value="erp.hr.hrBean"/>
</create>
:
</allow>
</dwr>
130. 131. (4) クライアントコード記述 dwrAddEmpHdr.htm 1/2
<?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;
} 131
132. function initOnLoad(){
setListener(id("add"), "click", addEmpHdr); dwrAddEmpHdr.htm 2/2
}
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> 132
133. 134. public String revEmpHdr(String emp_no){
Connection con = null; (1) サーバコード記述
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(); revEmpHdr
return resp;
}
135. 136. <?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]; (3) クライアントコード記述
id("depart").innerHTML = resp1[2];
id("section").innerHTML = resp1[3]; dwrRevEmpHdr.htm 1/2
id("ent_date").innerHTML = resp1[4];
}
137. function initOnLoad(){
setListener(id("rev"), "click", reqEmpHdr);
} dwrRevEmpHdr.htm 2/2
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>
138. 139. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" dwrRevEmpHdrKey1.htm
"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);
}
} if(idv("emp_no").length == 8){
function respEmpHdr(resp){ hrBean.revEmpHdr(idv("emp_no").toUpperCase(), respEmpHdr);
dispitems(resp, "emp_name"); }
}
function initOnLoad(){
setListener(id("emp_no"), "keyup", reqEmpHdr);
}
setListener(window, "load", initOnLoad);
//]]>
</script>
140. </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>
141. 142. <?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;
}
--> dwrRevEmpHdrAuto1.htm
</style>
143. <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();
}
}
144. 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];
}
}
145. 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";
}
146. 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>
147. 148. <?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";
149. 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);
}
150. }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>
151. 152. 153. <?xml version="1.0" encoging="UTF-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" addJournal.htm
"http://www.w3.org/TR/xhtml1/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja"> 1/3
<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;
}
}
}
}
154. 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 addJournal.htm
+ "&credit_code="+credit_code.value
+ "&credit_acct="+credit_acct.value 2/3
+ "&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>
155. <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> addJournal.htm
</tr>
</table> 3/3
<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>
156. addJournal 短縮形
//<![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"));
}
}
//]]>
157. <?php
$acct_code = $_GET["acct_code"];
setDebitAcct.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("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";
}
?>
158. <?php
$acct_code = $_GET["acct_code"]; addJournal.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("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";
}
?>
159. 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)
)
勘定テーブル
160. 161. 162. 163. 164. /bomTree1.htm
<?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();
165. 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);
}
166. 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+='------';
}
167. 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);
}
}
}
168. 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. 171. 172. <?xml version="1.0" encoding="utf-8" standalone="no"?>
scale.htm <!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>
172
173. 174. droppable.htm 1/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">
<!--
#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>
174
175. droppable.htm 1/2
<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>
175
176. ソート(Sortable)
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 : ソートされ順序が変更された時の処理 176
onUpdate : ソートされ順序が変更された後の処理
177. 178. 179. <style type="text/css" media="screen">
sort1.htm <!--
#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> 179
180. Ajaxでのコールバック処理
リクエスト待受
リクエスト送信
クライアント型処理
N
条件成就?
Y
サーバ型処理
レスポンス待受 レスポンス送信
クライアント サーバ
181. 182. cback.htm
<?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>
183. cback.js
//<![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);
}
184. 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();
}
}
}
}
185. 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);
//]]>
186. cback.java
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 = "";
187. 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();
}
}
188. 189. cbacks.htm
<?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> cbacks.htm
<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>
190. cbacks.js
//<![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();
}
}
}
191. 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);
//]]>
192. cbacks1.java
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");
193. 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();
}
}
194. 195. 196. Plotr
Ajaxモデルでのグラフ作成
http://www.solutoire.com/plotr
・グラフ作成
-棒グラフ
-折れ線グラフ
-円グラフ
・ブラウザサポート
Firefox 1.5+
Safari 2.0+
Opera 9.0+
IE6+ (emulated)
・BSD LIcense
BSD License
・無保証であることの明記と著作権表示だけを再頒布の条件とする。
・著作権表示を行えば、BSDライセンスのソースコードを他のプログラム
に組み込み、組み込み後のソースコードを非公開にできる。 196
197. 198. 199. 棒グラフ表示例ー1 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>
<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); 1.canvasタグで描画領域を設定し
//]]>
</script> ID名を指定。
</head>
<body>
<h2>Draw Pie1 <input type="button" id="draw" value="グラフ表示" /></h2>
<div><canvas id="graph" height="300" width="600"></canvas></div>
</body> 199
</html>
200. 棒グラフ表示例-1 javascript
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: [ 2.canvasタグのID名を
{v:0, label:"商用Unix"},
Plotr.BarChart()の最初のパラメータとして指定
{v:1, label:"FreeBSD"},
{v:2, label:"Linux"}, 3.2番目のパラメータはグラフを描画するオプション
{v:3, label:"Windows"} を指定。
]
};
var bar = new Plotr.BarChart("graph", options);
bar.addDataset(dataset);
bar.render();
}
200
201. 202. 棒グラフ表示例-2 javascript
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();
}
202
203. 204. 棒グラフ表示例-3 function drawGraph(){
javascript 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();
} 204
205. 206. 207. 折線グラフ表示例-1
javascript
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();
}
207
208. 209. 折線グラフ表示例-1
javascript
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();
} 209
210. 211. 212. 円グラフ表示例
javascript
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();
}
212
213. 214. 215. 216. 受注情報登録でのAjax適用
←顧客IDまたはTEL
入力と同時に顧客情報
を自動表示
←カレンダ日付けクリック
で受注関連年月日情報
の入力と変更
←商品IDと数量入力で
-商品名自動表示
-小計と合計額自動表示
217. 218. 219. 220. ロングテイル
Webサービス
DB 集合知 ・プログラマブルWeb
ユーザ参加
Google 貢献者としてのユーザ ・マッシュアップ
Yahoo!
Amazon RSS
ATOM wiki
blog ユーザ参加
公開 SOAP
HTTP sns 貢献者としてのユーザ
REST +
XML
集合知
DB 根本的な信頼
Ajax API
Folksonomy
プラットホームとしてのWeb
マッシュアップ ユーザーの手による情報の自由な整理
リッチなユーザ体験
マッシュアップ XHR
Ajax DB
適用業務 DB
マルチデバイス
社内システム
221. マッシュアップ構成とライブラリの粒度
サイト内 外部インターネット
(プログラマブルWeb)
[Webクライアント] [Webサーバ]
・Google AJAX
Search API
Type1 REST ・Google Maps API
サーバ ・Google SOAP
Type2 XHR SOAP/REST Search API
プログラム
サーバ
Type3 XHR プログラム アプリケーション
プログラム
ライブラリ
大粒度:コンポーネント
Web ・Yahoo!UIカレンダ ・Plotrグラフ作成
ブラウザ
中度:コントロール ・ActiveWidgets
ダウン
・Script.aculo.us
ロード
Ajax 小粒度:言語機能 ・Prototype.js
222. マッシュアップ構成とライブラリの粒度
サイト内 外部インターネット
(プログラマブルWeb)
[Webクライアント] [Webサーバ]
IMG ・Google AJAX
Search API
Type1 REST ・Google Maps API
サーバ ・Google SOAP
Type2 XHR SOAP/REST Search API
プログラム
サーバ
Type3 XHR プログラム アプリケーション
プログラム
ライブラリ
大粒度:コンポーネント
Web ・Yahoo!UIカレンダ ・Plotrグラフ作成
ブラウザ
中度:コントロール ・ActiveWidgets
ダウン
・Script.aculo.us
ロード
Ajax 小粒度:言語機能 ・Prototype.js
223. Google Maps API
Google Mapsの使い方
(1) Googleアカウントを所得
https://www.google.com/accounts/
ManageAccount
(2)Google Maps APIキーの所得
http://www.google.com/apis/maps/
224. 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-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>
225. 226. <?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);
227. 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>
228. 229. gmaddr.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">
<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);
}
}
230. 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. Yahoo! UI Library http://developer.yahoo.com/yui/
JavaScriptで記述され
たWebクライアント用
総合ライブラリ
231
233. Yahoo UI Library モジュール区分
Animation Motion
Button Panel
Calendar Point
Connection Region
Dom Scroll
DragDrop Slider
Event TabView
Logger TreeView
Menu YAHOO
233
234. 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> 235
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);
//]]>
236
237. 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);
//]]>
238
239. 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> 240
241. 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> 242
</html>
243. 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> 244
</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();
}
245
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> 247
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);
//]]> 248
249. 250. calendar4.htm (1/4)
<?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>
251. calendar4.htm (2/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");
252. cal1.selectEvent.subscribe(function(eventName, selectDate){
var sdate1 = selectDate.toString();
var sdate2 = sdate1.replace(",", "/").replace(",", "/");
$(fid).value = sdate2;
if(fid=="inqDate"){ calendar4.htm (3/4)
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>
253. calendar4.htm (4/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>
254. 255. dragdrop3.htm (1/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]]
};
256. dragdrop3.htm (2/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>
257. 258. 259. 260. 261. <?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");
262. 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);
}
263. 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>
264. 265. <?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)));
}
}
266. 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>
267. 268. 269. 270. 271. 272. 273. 274. [2] JavaScript関数での実行
(1) タブコントロール
コード12(1/3)
<?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" />
274
275. <style type="text/css"> コード12(2/3)
#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(); 275
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>
276
277. コード12(3/3)
</head>
<body>
<div class="t3"> Ajax サイト&サンプル</div>
<div> 本サイトへのお問合せは右記メールアドレスへお願いします。(katu@hows.ws)
<div> 方法/理由の如何を問わず本サイト掲載プログラムの無断コピーを禁止します。</div>
<p id="menuTabs"><div style="border-top: 1px solid #999"></div></p>
<p id="menu"></p>
</body>
</html>
277
278. 279. コード17(1/2)
<?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"};
279
280. コード17(2/2)
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>
280
281. 282. //<![CDATA[
var rows, cols; spread1.js
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);
//]]>
283. 284. グリッド表示サンプル XHTML grid1.htm
<?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>
284
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;}
--> 285
286. グリッド表示サンプル JavaScript grid1.js(1/2)
//<![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 = [“ティカー”, “会社名”, “マーケット”, “$セールス”, “従業員数”];
//グリッドタイトルの指定 286
287. grid1.js(2/2)
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);
//]]>
287
288. 289. XHTML コード30(1/2)
<?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>
289
290. コード30(2/2)
<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>
290
291. CSS コード31(1/2)
<!--
#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;} 291
292. コード31(2/2)
#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;}
-->
292
293. JavaScript コード21(1/8)
//<![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;
} 293
294. コード21(2/8)
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);
294
295. for(j=0; j<rows; j++){
myData[j] = new Array(cols);
} コード21(3/8)
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){
295
296. gridw = 28 + 80 * cols;
gridh = 460; コード21(4/8)
}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);
296
297. コード21(5/8)
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>";
} 297
298. out += "</table>";
document.getElementById("out2").innerHTML = out; コード21(6/8)
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>"); 298
299. var1 = recs[0].split("<i>");
rows = var1[0];
cols = var1[1]; コード21(7/8)
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"){
299
300. コード21(8/8)
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);
//]]>
300
301. [演習-5] スプレッドシート作成
コンボボックスで指定した行、列でグリッド表示
301
302. 303. //<![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);
}
}
}
304. 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;
}
}
305. 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 スプレッドシート作成
ファイル名でデータ参照機能の追加
306
307. 演習-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");
}
308. function showGrid(rows, cols, flag){
var i, j, k, row, col, cell_text;
if(flag == "new"){ 受信データの配列セット
: (1/2)
}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);
}
:
309. 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)
}
310. 311. UIとサーバ通信の分離 Java Beans DB
(POJO)
DWRサーブレット
ActiveWidgets ①イベント処理
Web DWR
他コンポーネント
GUI
②サーバ通信
③UI表示
plotr
④表示制御 ⑤演算処理
Ajaxエンジン
312. 313. 314. 315. マクロ登録と実行 (1,8) = (1,2) * (1,3) (2,8) = (1,7) - (1,6) * 2
316. 317. 318. 319. 320. 321. 322. [1] 簡単なサンプル
-bodyタグ内での実行
-ActiveWidgetsオリジナル
1 グリッド
<html>
<head> コード1
<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> 322
323. 2 タブ
コード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> 323
</html>
324. 3 コンボボックス
<html> コード3(1/2)
<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); //コンボリストへのテキスト割り当て
324
325. 326. 4 ツリー
<html> コード4(1/2)
<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]};
//ツリー表示テキストをツリー構造に割り当て
326
327. var tree = new AW.UI.Tree; //ツリーインスタンス生成 コード4(2/2)
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>
327
328. 329. 5 チェックリスト
コード5(1/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"></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); //チェックボックス表示項目数指定
329
330. 331. 6 ラジオボタン
コード6(1/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="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); //ラジオボタン表示数指定
331
332. 333. 7 リスト
コード7(1/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="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); //リストへ表示画像割り当て
333
334. 335. 8 グループ
コード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>
335
336. 9 インプット
コード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>
336
337. 10 ボタン
コード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>
337
338. 11 リンク
コード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>
338
339. 340. 341. エフェクト(Effect)
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 341
342. 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
343
344. 345. <?xml version="1.0" encoding="utf-8" standalone="no"?>
blindup.htm <!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> 345
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
346
347. 348. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
blindup.htm "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> 348
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
349
350. 351. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
dropout.htm "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> 351
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 352
353. 354. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
dropout.htm "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> 354
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 355
356. 357. <?xml version="1.0" encoding="utf-8" standalone="no"?>
fold.htm <!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> 357
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 358
359. 360. grow.htm <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>
360
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 361
362. 363. <?xml version="1.0" encoding="utf-8" standalone="no"?>
highlight.htm <!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>
363
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 364
365. 366. <?xml version="1.0" encoding="utf-8" standalone="no"?>
moveby.htm <!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>
366
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
367
368. 369. <?xml version="1.0" encoding="utf-8" standalone="no"?>
opacity.htm <!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>
369
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 370
371. 372. <?xml version="1.0" encoding="utf-8" standalone="no"?>
puff.htm <!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>
372
</html>
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 373
374. 375. <?xml version="1.0" encoding="utf-8" standalone="no"?>
pulsate.htm <!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>
375
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 376
377. 378. <?xml version="1.0" encoding="utf-8" standalone="no"?>
scale.htm <!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>
378
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
379
380. 381. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
scrollto.htm "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> 381
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
382
383. 384. shake.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>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>
384
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 385
386. 387. shrink.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>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>
387
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 388
389. 390. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
slidedown.htm "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> 390
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 391
392. 393. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
slidedown.htm "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> 393
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 394
395. 396. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
squish.htm "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>
396
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 397
398. 399. <?xml version="1.0" encoding="utf-8" standalone="no"?>
switchoff.htm <!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> 399
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
400
Effect.Transitions.full
401. 402. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
parallel1.htm "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> 402
</body>
</html>
403. 404. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
parallel2.htm "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>
405. 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 : ドラッグ終了時のエフェクト
406
407. 408. draggable.htm <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>
408
409. destory ドラッグオブジェクトを破棄(固定)する
書式
draggableObj.destroy()
draggableObj : ドラッガブルオブジェクト
409
410. 411. <style type="text/css">
<!--
destory.htm .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> 411
412. 413. return.htm <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>
413
414. Droppable.add ドロップ可能領域を指定する
書式
Droppables.add(element, option)
element : ドロップ領域を示すエレメント
option : オプション【省略可能】
accept : ドロップ可能なCSSクラス名
containt : 並べ替え可能を示すエレメント/配列
hoverclass : ドロップ中に適用するスタイルシートクラス
overlap : 並べ替え時に使用(horizontalまたはvertical)
greedy : 他のドロップ領域を検索しない
onHover : ドロップ中の処理
onDrop : ドロップされた時の処理
414
415. 416. droppable.htm 1/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">
<!--
#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>
416
417. droppable.htm 1/2
<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>
417
418. 419. droppable 2.htm 1/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: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>
419
420. <script type="text/javascript" charset="utf-8">
//<![CDATA[
function func1(){
droppable 2.htm 2/2
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> 420
421. 422. remove.htm 1/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: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">
422
423. remove.htm 2/2
<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> 423
424. 425. droppable3.htm (1/3)
<?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>
426. <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(){ droppable3.htm (2/3)
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"
});
}
427. droppable3.htm (3/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>
428. 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 : スライダーが取る値(配列で指定)
429
430. sliderObj = new Control.Slider(handle, track, options)
・最初のパラメータにはスライダーのハンドル(ドラッグして動かす部分)
を指定。
・2番目のパラメータにはトラック(スライダーの可動範囲)のエレメント
を指定。
・3番目のオプションでスライダーの各種設定を行う。
※スライダー値の範囲を指定するにはrange:$R(0,100)のように指定。
430
431. 432. slider1.htm <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>
432
433. 434. slider2.htm <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>
434
435. 436. slider3.htm <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>
436
437. 438. slider4.htm <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>
438
439. 440. <style type="text/css">
<!--
slider5.htm #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> 440
</html>
441. ソート(Sortable)
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 : ソートされ順序が変更された時の処理 441
onUpdate : ソートされ順序が変更された後の処理
442. 443. 444. <style type="text/css" media="screen">
sort1.htm <!--
#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> 444
445. 446. sort2.htm <<?xml version="1.0" encoding="utf-8" standalone="no"?>
1/2 <!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>
446
447. soer2.htm <script type="text/javascript" charset="utf-8">
2/2 //<![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>
447
448. 449. <style type="text/css" media="screen">
<!--
#list1 { width:250px; padding: 2px; background:#c03;}
sort3.htm #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> 449
</html>
450. 451. <?xml version="1.0" encoding="utf-8" standalone="no"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 dragsort1.htm
Transitional//EN" (1/3)
"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>
452. <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[ dragsort1.htm
function loadFunc(){ (2/3)
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>
453. </head> dragsort1.htm
<body> (3/3)
<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>
454. 455. 456. 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">
//<![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>
456
457. 非同期通信との組み合わせ editor1.htm (1/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>
<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>
458. 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);
//]]>
459. init1.php
<?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";
}
?>
460. edit1.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;
}
?>
461. 462. <script type="text/javascript" src="../lib/funcs.js"></script>
editor2.htm <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> 462
463. 464. <script type="text/javascript" src="../lib/funcs.js"></script>
editor3.htm <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> 464