Skip to content

Instantly share code, notes, and snippets.

@think49
Created September 28, 2010 13:00
Show Gist options
  • Save think49/600934 to your computer and use it in GitHub Desktop.
Save think49/600934 to your computer and use it in GitHub Desktop.
PuzzleTable.js : mouseover したり、click すると画像が切り替わるパズル的な何か
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8" />
<title>PuzzleTable</title>
<style type="text/css"><!--
table { padding: 0; border-collapse: collapse; border-style: none; border-width: 0; }
tbody, tr, td { margin: 0; padding: 0; }
td img { margin: 0; padding: 0; vertical-align: bottom; }
--></style>
<script><!--
// PuzzleTable.js
(function () {
// PuzzleTable
function PuzzleTable () {
this.init.apply(this, arguments);
return this;
}
PuzzleTable.prototype.create = function (doc) {
if (!doc || !doc.createElement) throw new TypeError (doc + ' is not HTMLDocument');
var rowsLength = this.rowsLength, cellsLength = this.cellsLength, imageFiles = this.imageFiles;
var table = doc.createElement('table'), imgs = [doc.createElement('img'), doc.createElement('img')], tBodies, trs, i, l, tr, cells;
if (rowsLength < 2) throw new Error ('"rowsLength" has to be the numerical value of more than 2');
table.className = 'mouseoverMode';
tBodies = table.appendChild(doc.createElement('tbody'));
trs = [tBodies.insertRow(0), tBodies.insertRow(1)];
imgs[0].src = imageFiles[0];
imgs[0].className = 'puzzle';
imgs[1].src = imageFiles[1];
imgs[1].className = 'puzzle';
for (i = 0, l = cellsLength, tr = trs[0], cells = tr.cells; i < l; i++) {
tr.insertCell(cells.length).appendChild(imgs[i % 2].cloneNode(false));
}
for (i = 1, l = cellsLength + 1, tr = trs[1], cells = tr.cells; i < l; i++) {
tr.insertCell(cells.length).appendChild(imgs[i % 2].cloneNode(false));
}
for (i = 2, l = rowsLength; i < l; i++) {
tBodies.appendChild(trs[i % 2].cloneNode(true));
}
this.table = table;
return this;
};
PuzzleTable.prototype.addEvent = function (listener) {
var table = this.table;
if (typeof listener !== 'function') throw new TypeError(listener + ' is not function');
if (!table) throw new Error('table is not defined');
if (table.addEventListener) {
table.addEventListener('mouseover', listener, false);
table.addEventListener('click', listener, false);
} else if (table.attachEvent) {
table.attachEvent('onmouseover', listener);
table.attachEvent('onclick', listener);
}
return this;
};
PuzzleTable.prototype.init = function (imageFiles, rowsLength, cellsLength) {
if (Array.isArray ? !Array.isArray(imageFiles) : (typeof imageFiles !== 'object' || Object.prototype.toString.call(imageFiles) !== '[object Array]')) throw new TypeError(imageFiles + ' is not Array');
if (rowsLength) this.rowsLength = rowsLength;
if (cellsLength) this.cellsLength = cellsLength;
this.imageFiles = imageFiles;
return this;
};
PuzzleTable.prototype.rowsLength = 10;
PuzzleTable.prototype.cellsLength = 10;
// puzzleTableListener
function puzzleTableListener (event) {
var img, type, td, table, src, imgList;
img = event.target || event.srcElement;
type = event.type;
src = img.getAttribute('src');
td = img ? img.offsetParent : null;
table = td ? td.offsetParent : null;
if (type !== 'mouseover' && type !== 'click') return;
if (img.tagName.toLowerCase() !== 'img') return;
if (!src) return;
if ((' ' + img.className + ' ').indexOf(' puzzle ') === -1) return;
if (!td || td.tagName.toLowerCase() !== 'td') return;
if (!table || table.tagName.toLowerCase() !== 'table') return;
if ((' ' + table.className + ' ').indexOf(' ' + type + 'Mode ') === -1) return;
imgList = [
'',
'',
'',
'',
'',
''
];
for (var i = 0, l = imgList.length; i < l; i++) {
if (src === imgList[i]) img.src = imgList[(i + 2) % l];
}
}
// DOMContentLoaded (for IE)
function createDOMContentLoadedForIE (listener) {
if (!this.document.createComment().doScroll) return;
return function () {
try {
this.document.createComment().doScroll();
listener({ target:this.document, type:'DOMContentLoaded' });
} catch (error) {
setTimeout(arguments.callee, 1);
}
};
}
// domContentLoadedListener
function domContentLoadedListener (event) {
var doc = event.target, puzzle, table,
imgList = [
'',
''
];
puzzle = new PuzzleTable(imgList).create(doc).addEvent(puzzleTableListener);
table = puzzle.table;
table.id = 'PUZZLE';
doc.body.appendChild(table);
if (doc.addEventListener) {
doc.addEventListener('click', clickListener, false);
} else if (doc.attachEvent) {
doc.attachEvent('onclick', clickListener);
}
}
function clickListener (event) {
var input = event.target || event.srcElement, doc = input.ownerDocument, table, className, mode;
if (input.id !== 'CHANGE_MODE') return;
if (table = doc.getElementById('PUZZLE'), !table|| table.tagName.toLowerCase() !== 'table') return;
if (className = table.className, !className) return;
for (var i = 0, className = ' ' + className + ' ', classList = ['mouseoverMode', 'clickMode'], l = classList.length; i < l; i++) {
if (className.indexOf(' ' + classList[i] + ' ') !== -1) {
className = className.replace(new RegExp(' ' + classList[i] + ' ', 'g'), classList[(i + 1) % 2]);
className = className.trim ? className.trim() : className.replace(/^\s+|\s+$/);
table.className = className;
mode = /^(\w+)Mode$/.exec(className);
input.value = mode[1] + ' Mode';
break;
}
}
event.preventDefault ? event.preventDefault() : event.returnValue = true;
}
// initialization
if (document.addEventListener) {
document.addEventListener('DOMContentLoaded', domContentLoadedListener, false);
} else if (document.createComment().doScroll) {
createDOMContentLoadedForIE.call(this, domContentLoadedListener).call(this);
}
}).call(this);
//--></script>
</head>
<body>
<h1>PuzzleTable</h1>
<p>mouseover したり、click すると画像が切り替わるパズル的な何か。</p>
<p>このスクリプトを動作させるためには、detaスキームに対応するブラウザが必要です。(IE7- は不可)<br />IE7- に対応させる場合は、5つの画像ファイルを用意して imgList にそれぞれのファイル名を代入してください。</p>
<ul>
<li><a href="http://www.cityfujisawa.ne.jp/~intvsn/OnMouseKolam/OnMouseKOLAM.htm">OnMouseKolamDrawer</a></li>
<li><a href="http://www.tagindex.com/cgi-lib/q4bbs/patio.cgi?mode=view&amp;no=2677">掲示板/JavaScript質問板/&lt;img src=&quot;1s.gif&quot; 文をForに? - TAG index Webサイト</a></li>
</ul>
<p>下記の仕組みで画像が切り替わります。</p>
<ul>
<li>imgList[0] -> imgList[2] -> imgList[4] -> imgList[0] -> (loop)</li>
<li>imgList[1] -> imgList[3] -> imgList[5] -> imgList[1] -> (loop)</li>
</ul>
<p>ボタンをクリックすると、画像が切り替わる条件が変更されます。</p>
<form>
<p><input type="button" id="CHANGE_MODE" name="mode" value="mouseover Mode" tabindex="0" /></p>
</form>
<hr />
</body>
</html>
@think49
Copy link
Author

think49 commented Sep 28, 2010

掲示板/JavaScript質問板/<img src="1s.gif" 文をForに? - TAG index Webサイト
http://www.tagindex.com/cgi-lib/q4bbs/patio.cgi?mode=view&no=2677

にポストしたコード。

@think49
Copy link
Author

think49 commented Sep 29, 2010

2010-09-25 - babu_babu_babooのごみ箱
http://d.hatena.ne.jp/babu_babu_baboo/20100925#c1285752235

gtlt さんのアドバイスを参考にしています。感謝!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment