jquery 一類的 javascript 庫
在web2.0 以前, 只能說是玩樂, 觀賞性質
甚至老牌的教科書會說不要使用javascript
免得面對瀏覽器兼容的問題
但隨著ajax, web2.0 等新世代名詞出現
gmail, yahoo pipes 等的出現
javascript 已經成為網頁元素必然的一部分
jquery, prototype, moto 等的通用庫的出現
更進一步推動javascript 的發展
Drupal 在5.0 之後正式支援jquery
但大家可能只會在上傳檔案時見到它的出現
其餘的core 部分幾乎都沒有用到jquery
留下一大塊可開發的地方
也直接促成tabbed block 的開發
入正題
drupal 因為已經內建jquery
使用上已經提供很多方便的函數, 方法
所以要使用jquery, 技術上難度不大
但要在效能和功能上取得平衡
便需要點實作的經驗和測試了
先約略介紹jquery 的操作
在一頁網頁裏, 代碼要從眾多的元素(element) 裏選出目標對象
然後再處理
一般會使用id, class, tags 等方法, 和使用css 類似
其中id 最直觀
<a id="link1">hyper link</a>
css 裏
<style>
#link1{color:red;}
</style>
#link1 中的# 代表id 的意思
便指定id 為 link1 的任何東西(id 在一頁裏應為唯一)
字體都是紅色
如果我要用jquery 令id 為 link1 的元素隱藏:
$("#link1").hide()
$("#link1")指定了一個或一些元素(id 在一頁裏應為唯一)
.hide() 令他們隱藏
相似的,
.link 的 . 代表class
input 代表input tag 等
都可以用在jquery 內
$(".link").show()
$("input").fadeIn()
註: jquery 代碼要放到<script></script>內
css 要放到<style></style>內
更進一步, 例如:
<ul id="list">
<li>a</li>
<li>b</li>
</ul>
$("#list") 找到 <ul id="list">
$("#list").children("li") 便可以找到id 為list, 子元素為li (共二個)
$("#list").children("li").eq(0) 便可以找到id 為list, 子元素為li, 的第零個元素 (<li>a</li>)
$("#list").children("li").eq(0).hide()....
jquery 稱這連續的選擇方式為"chained"
到了這個部分
當看見jquery 的代碼
應該可以明白它的工作原理
然後到jquery.com 找一找沒有看過的函數 toogle(), attr() 等等
一里通, 百里明
這些代碼都可以放在theme 內
直接顯示, 處理
本站的menu 漸變都是用此方式植入
因為這屬於theme 的管轄範圍
放在theme 內合情合理
今天就先介紹到這裡....
2007年11月23日 星期五
2007年8月20日 星期一
GoogleMapAPI簡單介紹
最近在網路上有看到一個特別的網站,叫做臺灣美女地理雜誌看起來好像很棒,所以,也去稍微看了一下,才發現Google提供了那麼好的服務。
在 Google 推出 Google Maps 之後,網路上出現各種 hack 網站及文件,討論如何直接從 Google Maps 的 CGI 取得地圖圖檔並推出自己的地圖服務,但是這類的網站對 Google 的負荷很大,例如前不久的 Google Maps Wallpaper 即是,大量無節制的下載圖檔,Google 沒多久就將他封殺了,而且各式 hacking 的程式良莠不齊,所以 Google 就乾脆自己推出 API 程式庫讓全世界對 Google Maps 有興趣的程式設計師能夠自行開發 Google Maps 服務,而且 Google 也可以透過 API 來對這些服務做一個控管。
這篇文章主要要介紹如何利用 Google Maps API 來把 Google 所提供的地圖服務內嵌到你的網頁中,看過這篇介紹後,你會發現這是多麼簡單的一件事情。如果你有興趣,不妨一起討論討論,或許你也可以想出很有創意的應用來。
Goole Maps API 使用上有些法律上的限制要注意:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8"/>
<title>Google Maps JavaScript API Example</title>
<script src="http://maps.google.com/maps?file=api&v=2&key=abcdefg"
type="text/javascript"></script>
<script type="text/javascript">
//<![CDATA[
function load() {
if (GBrowserIsCompatible()) {
var map = new GMap2(document.getElementById("map"));
map.setCenter(new GLatLng(37.4419, -122.1419), 13);
}
}
//]]>
</script>
</head>
<body onload="load()" onunload="GUnload()">
<div id="map" style="width: 500px; height: 300px"></div>
</body>
</html>
紅字的部分就是用你取得的 Key 去載入 Google Maps API,這裡要注意的是,你一定要用你自己的 URL 去取得這把 Key,否則網頁在載入時,會得到錯誤訊息。接下來,宣告一個 div 區塊用來擺置地圖,style="width: 300px; height:300px" 則是用來指定地圖區塊大小。
再來利用 var map = new GMap (document.getElementById("mymap")); 宣告一個 GMap 物件。而 map.centerAndZoom(new GPoint(139.7600, 35.6700), 1); 則是將地圖的中心點固定在經度 139.7600 和緯度 35.6700,而 Zoom Level 在這範例中設成 1 (1 為最大,數字越大 Zoom Level 越小)。在這邊你或許會有個疑問,要怎麼知道某個地點的經緯度?如果你是在美國或加拿大,有些網站會提供依照地址查詢經緯度的服務,但是其他國家就比較麻 煩了,而我有個比較簡單的方法你可以參考看看,也就是先利用 Google Maps 的大地圖找到你要的地點,將他固定在中間,然後按下網頁上的 Link to this page,這時候 Google Maps 就會顯示出這頁的 URL,URL 上就有該點的經緯度了,舉例來說,我想要找出日本京都車站的經緯度,我先用 Google Japan Maps 找到車站位置,並將他固定在中心,最後並取得連結:http://maps.google.co.jp/maps?ll=34.982050,135.761490&spn=0.012443,0.020262&hl=ja,紅字所標的就是京都車站的經緯度。
這個範例中,你有沒有覺得是不是少了什麼?那就是少了 Google Maps 中的控制項,沒有這個你沒辦法放大縮小地圖,也沒辦法切換衛星空照圖。如下範例你就可以在你的地圖中加入這兩個控制項:
var map = new GMap2(document।getElementById("map")); //這一行是建立地圖元件
map . addControl(new GSmallMapControl()); //這一行是建立小地圖地圖縮放控制項
map . addControl(new GMapTypeControl()); //這一行是建立地圖種類控制項
map . setCenter(new GLatLng(37।4419, -122।1419), 13); //這一行是地圖的中心點左邊的是經度右邊是緯度最右邊的13是大小
今天就先打到這接下來就看各位有沒有與趣了解更多了。
在 Google 推出 Google Maps 之後,網路上出現各種 hack 網站及文件,討論如何直接從 Google Maps 的 CGI 取得地圖圖檔並推出自己的地圖服務,但是這類的網站對 Google 的負荷很大,例如前不久的 Google Maps Wallpaper 即是,大量無節制的下載圖檔,Google 沒多久就將他封殺了,而且各式 hacking 的程式良莠不齊,所以 Google 就乾脆自己推出 API 程式庫讓全世界對 Google Maps 有興趣的程式設計師能夠自行開發 Google Maps 服務,而且 Google 也可以透過 API 來對這些服務做一個控管。
這篇文章主要要介紹如何利用 Google Maps API 來把 Google 所提供的地圖服務內嵌到你的網頁中,看過這篇介紹後,你會發現這是多麼簡單的一件事情。如果你有興趣,不妨一起討論討論,或許你也可以想出很有創意的應用來。
申請一組 Google Maps API Key
在使用 Google Maps API 之前,你必須向 Google 申請到一組 Key,申請的方法很簡單:- 首先,先決定你的網頁會出現在哪個 URL, 例如我想把 Google Maps 嵌入到我的 blog 中,我可以先知道該網頁的 URL 應該會是 http://blog.yam.com/syshen/archives/XXXX.html,前面包含到最後一個目錄的字串便是要來申請 Key 的基準,也就是 http://blog.yam.com/syshen/archives/。
- 以你的帳號登入 Google,如果你還沒有帳號,請到 https://www.google.com/accounts/ 申請。
- 連到 Google Maps API Sign Up 網頁將 (1) 所決定的 URL 填入,並按 "Generate API Key" 取得 Key。
- 最後會出現三個方塊,分別是你取得的 Key,你指定的 URL,以及一個範例。建議是將範例中的 整行 Copy/Paste 下來。
Goole Maps API 使用上有些法律上的限制要注意:
- 你的 Google Maps 服務必須免費開放給一般使用者。
- 如果你預估你的地圖服務會有超過每天 50,000 筆頁面的存取量,請主動聯絡 Google。
- Google 會不定期更新 API,你有責任跟著更新你的網頁中的 API。
- 你不能更改或隱藏 Google 的 logo。
- Google 有權力以後在地圖上放廣告,而你不能更改或破壞這些廣告。
- 有些地圖應用是 Google 不希望看到的,例如指明哪些地方可以購買到毒品或是任何違法行為。
第一個範例:在網頁嵌入 Google Maps
當你取得一把 API Key 之後,我們就可以來寫第一個範例了,這個範例相當簡單:<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8"/>
<title>Google Maps JavaScript API Example</title>
<script src="http://maps.google.com/maps?file=api&v=2&key=abcdefg"
type="text/javascript"></script>
<script type="text/javascript">
//<![CDATA[
function load() {
if (GBrowserIsCompatible()) {
var map = new GMap2(document.getElementById("map"));
map.setCenter(new GLatLng(37.4419, -122.1419), 13);
}
}
//]]>
</script>
</head>
<body onload="load()" onunload="GUnload()">
<div id="map" style="width: 500px; height: 300px"></div>
</body>
</html>
紅字的部分就是用你取得的 Key 去載入 Google Maps API,這裡要注意的是,你一定要用你自己的 URL 去取得這把 Key,否則網頁在載入時,會得到錯誤訊息。接下來,宣告一個 div 區塊用來擺置地圖,style="width: 300px; height:300px" 則是用來指定地圖區塊大小。
再來利用 var map = new GMap (document.getElementById("mymap")); 宣告一個 GMap 物件。而 map.centerAndZoom(new GPoint(139.7600, 35.6700), 1); 則是將地圖的中心點固定在經度 139.7600 和緯度 35.6700,而 Zoom Level 在這範例中設成 1 (1 為最大,數字越大 Zoom Level 越小)。在這邊你或許會有個疑問,要怎麼知道某個地點的經緯度?如果你是在美國或加拿大,有些網站會提供依照地址查詢經緯度的服務,但是其他國家就比較麻 煩了,而我有個比較簡單的方法你可以參考看看,也就是先利用 Google Maps 的大地圖找到你要的地點,將他固定在中間,然後按下網頁上的 Link to this page,這時候 Google Maps 就會顯示出這頁的 URL,URL 上就有該點的經緯度了,舉例來說,我想要找出日本京都車站的經緯度,我先用 Google Japan Maps 找到車站位置,並將他固定在中心,最後並取得連結:http://maps.google.co.jp/maps?ll=34.982050,135.761490&spn=0.012443,0.020262&hl=ja,紅字所標的就是京都車站的經緯度。
這個範例中,你有沒有覺得是不是少了什麼?那就是少了 Google Maps 中的控制項,沒有這個你沒辦法放大縮小地圖,也沒辦法切換衛星空照圖。如下範例你就可以在你的地圖中加入這兩個控制項:
var map = new GMap2(document।getElementById("map")); //這一行是建立地圖元件
map . addControl(new GSmallMapControl()); //這一行是建立小地圖地圖縮放控制項
map . addControl(new GMapTypeControl()); //這一行是建立地圖種類控制項
map . setCenter(new GLatLng(37।4419, -122।1419), 13); //這一行是地圖的中心點左邊的是經度右邊是緯度最右邊的13是大小
今天就先打到這接下來就看各位有沒有與趣了解更多了。
2007年7月20日 星期五
AJAX拖放欄位
這是之前類似IGOOGLE的拖放功能的JS程式碼
後半部
這是我個人認為比較難懂的地方
其他還有一點是用PHP寫的
今天就先不談
今天的重點是JS的部分
接續之前的那一個程式碼片段.....
function process(content,ation)
{
if(xmlhttp)
{
params = "";
content = encodeuricomponent(content);
if (action == "updatelist")
params="?content=" + serialize(content)+ "&action=updatelist";
else if (action=="addnewtask")
{
var newtask=trim(encodeuricomponent(document.getelementbyid(content).value));
if (newtask)
params="?content=" + new task +"&action=addnewtask";
}
else if (action=="deltask")
params="?content="+content+"&action=deltask";
if(params) cache.push(params);
try
{
if((xmlhttp.readystate == 4||xmlhttp.readystate==0)&&cache.length>0)
{
var cacheentry = cache.shift();
xmlhttp.open("Get","drag-and-drop.php"+cacheentry,true);
xmlhttp.setrequestheader("content-type","application/x-www-form-urlencoded");
xmlhttp.onreadystatechange=handlerequeststatechange;
xmlhttp.send(null);
}
else
{
settimeout("process();",1000);
}
}
catch(e)
{
displayerror(e.tostring());
}
}
}
function handlerequeststatechange()
{
if (xmlhttp.readystate ==4)
{
if(xmlhttp.status==200)
{
try
{
postupdateprocess();
}
catch(e)
{
displayerror(e.tostring());
}
}
else
{
displayerror(xmlhttp.statustext);
}
}
}
function postupdateprocess()
{
var response = xmlhttp.responsetext'
if(response.indexof("ERRNO")>=0||response.indexof("error")>=0)
alert(response);
document.getelementbyid("taskslist").innerhtml=response;
sortable.create("taskslist");
document.getelementbyid("txtnewtask").value="";
document.getelementbyid("txtnewtask").focus();
}
functi8on handlekey(e)
{
e=(!e)? windows.event:e;
code=(e.carcode ? e.charcode:
((e.keycode)?e.keycode:
((e.which)?e.which:0));
if(e.type=="keydown")
{
if(code==13)
{
process("txtnewtask","addnewtask");
}
}
}
function trim(s)
{
return s.replace(/(^\s+)|(\s+$)/g,"")
}
後半部
這是我個人認為比較難懂的地方
其他還有一點是用PHP寫的
今天就先不談
今天的重點是JS的部分
接續之前的那一個程式碼片段.....
function process(content,ation)
{
if(xmlhttp)
{
params = "";
content = encodeuricomponent(content);
if (action == "updatelist")
params="?content=" + serialize(content)+ "&action=updatelist";
else if (action=="addnewtask")
{
var newtask=trim(encodeuricomponent(document.getelementbyid(content).value));
if (newtask)
params="?content=" + new task +"&action=addnewtask";
}
else if (action=="deltask")
params="?content="+content+"&action=deltask";
if(params) cache.push(params);
try
{
if((xmlhttp.readystate == 4||xmlhttp.readystate==0)&&cache.length>0)
{
var cacheentry = cache.shift();
xmlhttp.open("Get","drag-and-drop.php"+cacheentry,true);
xmlhttp.setrequestheader("content-type","application/x-www-form-urlencoded");
xmlhttp.onreadystatechange=handlerequeststatechange;
xmlhttp.send(null);
}
else
{
settimeout("process();",1000);
}
}
catch(e)
{
displayerror(e.tostring());
}
}
}
function handlerequeststatechange()
{
if (xmlhttp.readystate ==4)
{
if(xmlhttp.status==200)
{
try
{
postupdateprocess();
}
catch(e)
{
displayerror(e.tostring());
}
}
else
{
displayerror(xmlhttp.statustext);
}
}
}
function postupdateprocess()
{
var response = xmlhttp.responsetext'
if(response.indexof("ERRNO")>=0||response.indexof("error")>=0)
alert(response);
document.getelementbyid("taskslist").innerhtml=response;
sortable.create("taskslist");
document.getelementbyid("txtnewtask").value="";
document.getelementbyid("txtnewtask").focus();
}
functi8on handlekey(e)
{
e=(!e)? windows.event:e;
code=(e.carcode ? e.charcode:
((e.keycode)?e.keycode:
((e.which)?e.which:0));
if(e.type=="keydown")
{
if(code==13)
{
process("txtnewtask","addnewtask");
}
}
}
function trim(s)
{
return s.replace(/(^\s+)|(\s+$)/g,"")
}
2007年7月17日 星期二
呼叫遠端伺服器javascript&php
好久沒發文了
這是用ajax的技術使用javascript
用戶端連結伺服器在以php連結遠端伺服器
最後在傳回用戶端
var xmlHttp = createXmlHttpRequestObject();
var serverAddress = "smartpoxyping.php;
var getNumberParams= "action=GetNumber" + "&min=1"+"&max=100";
var chechAvailabilityParams = "action=checkavailability;
var requestscount=0;
var checkinterval=10;
var updateinterval=1; '等待1秒取得新亂數
var updateintervalifserverbusy=10; '伺服器連線繁忙時等待10秒後重試
var minserverbufferlevel=50;
function createXmlHttpRequestObject()
{
var xmlhttp;
try
{
xmlhttp = new xmlhttprequest();
}
catch(e)
{
var xmlhttpversions = new array("MSXML2.XMLHTTP.6.0","MSXML2.XMLHTTP.5.0","MSXML2.XMLHTTP.4.0","MSXML2.XMLHTTP.3.0","MSXML2.XMLHTTP","Microsoft.XmlHTTP");
for (var i=0; i try
{
xmlhttp = new Activexobject(xmlhttpversions[i]);
}
catch(e){}
}
}
if (!xmlhttp)
alert("建立xmlhttprequest物件產生錯誤");
else
reurn xmlhttp;
}
function process()
{
if (xmlhttp)
{
try
{
if (requestscounter % checkinterval==0)
{
xmlhttp.open("GET",serveraddress+ "?" +checkavailabilityparams,true);
xmlhttp.onreadystatechange = handlecheckingavailability;
xmlhttp.send(null);
}
else
{
xmlhttp.open("GET",serveraddress+ "?" +checkavailabilityparams,true);
xmlhttp.onreadystatechange = handlegettingnumber;
xmlhttp.send(null);
}
}
catch(e)
{
alert("無法連結伺服器")
}
}
}
function handlecheckingavailability()
{
if (xmlhttp.readystate ==4)
{
if (xmlhttp.status ==200)
{
try
{
checkavailability();
}
chatch(e)
{
alert("伺服器連結錯誤");
}
}
else
{
alert("伺服器讀取錯誤");
}
}
}
function checkavailability()
{
var response = xmlhttp.responsetext;
if (response.length > 5 || response.length ==0)
throw(response.length ==0 ? "伺服器錯誤" : response);
mydiv = document.getelementbyid("mydivelement");
if(response >= minserverbufferlevel)
{
mydiv.innerHtml += "伺服器緩衝" + respnose + "%, " + "開始接收新數字
";
requestconnter++;
settimeout("process();",updateinterval*1000)
}
else
{
mydiv.innerHtml += "伺服器緩衝" + respnose + "%, " + "將重新檢查
";
settimeout("process();",updateinterval*1000)
}
}
這些為js的程式碼片段
懶的key註解了 = =
這是用ajax的技術使用javascript
用戶端連結伺服器在以php連結遠端伺服器
最後在傳回用戶端
var xmlHttp = createXmlHttpRequestObject();
var serverAddress = "smartpoxyping.php;
var getNumberParams= "action=GetNumber" + "&min=1"+"&max=100";
var chechAvailabilityParams = "action=checkavailability;
var requestscount=0;
var checkinterval=10;
var updateinterval=1; '等待1秒取得新亂數
var updateintervalifserverbusy=10; '伺服器連線繁忙時等待10秒後重試
var minserverbufferlevel=50;
function createXmlHttpRequestObject()
{
var xmlhttp;
try
{
xmlhttp = new xmlhttprequest();
}
catch(e)
{
var xmlhttpversions = new array("MSXML2.XMLHTTP.6.0","MSXML2.XMLHTTP.5.0","MSXML2.XMLHTTP.4.0","MSXML2.XMLHTTP.3.0","MSXML2.XMLHTTP","Microsoft.XmlHTTP");
for (var i=0; i
{
xmlhttp = new Activexobject(xmlhttpversions[i]);
}
catch(e){}
}
}
if (!xmlhttp)
alert("建立xmlhttprequest物件產生錯誤");
else
reurn xmlhttp;
}
function process()
{
if (xmlhttp)
{
try
{
if (requestscounter % checkinterval==0)
{
xmlhttp.open("GET",serveraddress+ "?" +checkavailabilityparams,true);
xmlhttp.onreadystatechange = handlecheckingavailability;
xmlhttp.send(null);
}
else
{
xmlhttp.open("GET",serveraddress+ "?" +checkavailabilityparams,true);
xmlhttp.onreadystatechange = handlegettingnumber;
xmlhttp.send(null);
}
}
catch(e)
{
alert("無法連結伺服器")
}
}
}
function handlecheckingavailability()
{
if (xmlhttp.readystate ==4)
{
if (xmlhttp.status ==200)
{
try
{
checkavailability();
}
chatch(e)
{
alert("伺服器連結錯誤");
}
}
else
{
alert("伺服器讀取錯誤");
}
}
}
function checkavailability()
{
var response = xmlhttp.responsetext;
if (response.length > 5 || response.length ==0)
throw(response.length ==0 ? "伺服器錯誤" : response);
mydiv = document.getelementbyid("mydivelement");
if(response >= minserverbufferlevel)
{
mydiv.innerHtml += "伺服器緩衝" + respnose + "%, " + "開始接收新數字
";
requestconnter++;
settimeout("process();",updateinterval*1000)
}
else
{
mydiv.innerHtml += "伺服器緩衝" + respnose + "%, " + "將重新檢查
";
settimeout("process();",updateinterval*1000)
}
}
這些為js的程式碼片段
懶的key註解了 = =
訂閱:
文章 (Atom)