올블로그를 보다가 Daum에서 위젯뱅크를 런칭했다는 글을 보고 한번 가보았습니다.

http://widgetbank.daum.net/

오.....위젯들이 한 곳에 모여있군요 ^^ 설치도 매우 쉽게 클릭하면 설치형 블로그이면, 설치형 블로그에 넣을 수 있는 코드를 리턴해주고, 티스토리는 계정을 등록해야하는군요.

그래서 저도 시계를 하나 가져왔습니다. 시계가 좀 간지나서-_-; 언제 내릴지 모르겠지만 ^^
제 블로그에는 위젯이 3개나 있는데요.
문자보내주는 엄지위젯, 랭킹을 보여주는 야후블로그검색 순위 뱃지, 그리고 방금 가져온 시계 위젯.

위젯이 블로그에 많아지면 블로그 로딩 속도도 느려지고, 여기저기 덕지덕지 붙어있는게 참 보기 안 좋을 수 있습니다. 그래서 자신의 블로그 스킨에 맞는 위젯을 가져와야하고, 꼭 필요한 위젯을 가져와야하죠 ^^

이 다음 위젯뱅크에서 좋은 점은 위젯을 미리 체험할 수 있군요(원래 다 그런가-_-)

더욱 재미있는 것은 게임도 있습니다-_-; 방금 퀴즈하고 볼링을 해봤는데, 우와 재미있네요 ^^
이 볼링은 공이 왜 랜덤으로 막 가는 것 같네-_-;

아직 위젯을 제작하는 회사는 얼마 되지 않아서 거의다 다음이 제작한 것 같습니다.

widget


아직 위젯을 가져오는 방법을 좀 더 쉽게 해주었으면 합니다만, 보안상 그건 좀 어려울지도 모르겠네요.
그 위젯 쉽게 가져오는 플러그인을 설치한 블로그에서는 여기서 위젯 가져오기 클릭하면 자동으로 위젯이 추가가 되어있어서 위젯 위치만 바꾸면 되는 뭐그런-_-; 할 수 있을까-_-;

암튼 여러분도 위젯을 달아보세요~ 블로그가 간지납니다~
 
Posted by 머드초보
,
 

최근 자바스크립트를 공부하고 있는데요.
방탄AJAX라는 책을 보고 있는데, 여기에는 yahoo로 하는 방법이 있어서 저는 daum으로-_-; prototype을 이용해서 더욱 간결하게(별로 간결하지않아-_-) 만들어봤습니다.

[code]
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
 <head id='headId'>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
  <title>Untitled Document</title>
  <script src="lib/prototype/prototype.js" type="text/javascript"></script>
  <script type="text/javascript" src="daumSearch.js"></script>
 </head>
 <body>
  <h1>Daum Blog Search!</h1>
  <form onsubmit="searchDaum(this.query.value); return false;">
   <fieldset>
    <label>Search for</label>
    <input type="text" name="query" />
    <input type="submit" value="검색" />
   </fieldset>
  </form>
  <div id="results"></div>
 </body>
</html>
[/code]
HTML은 간단합니다. prototype라이브러리를 선언하구요. 이제 작성할 daumSearch.js파일을 선언했군요.
그리고, form부분에서는 query라는 name을 가진 input에 쿼리를 날리면, searchDaum이라는 메소드를 호출하게 되어있습니다.
daumSearch.js를 보도록 합시다.

[code]
function getScript(url)
{
 var scripttag = new Element("script",{
   "type": "text/javascript",
   "src": url});
 var head = $$("head");
 head[0].insert(scripttag);
}

function searchDaum(query)
{    
 var url = "http://apis.daum.net/search/blog?"
 url += "q=" + encodeURIComponent(query);
 url += "&result=10";
 url += "&start=1";
 url += "&output=json";
 url += "&apikey=다음에서 apikey발급받고 넣으세요";
 url += "&callback=parseResponse";
 
 getScript(url);
}

function parseResponse(data)
{
 var children;
 var results = $("results");
 
 while (results.hasChildNodes())
 {
  results.removeChild(results.lastChild);
 }
 
 for (var i=0; i<data.channel.result; i++)
 {
  var title = data.channel.item[i].title;
  var summary = data.channel.item[i].description;
  var url = data.channel.item[i].link;
 
  var link = new Element("a", {"href":url, "target":"_blank"}).update(title);
  var header = new Element("h2").insert(link);
  var para = new Element("p").update(summary);
 
  results.insert(header);
  results.insert(para);
 }
}
[/code]
getScript함수는 해당 url을 head부분에 자바스크립트 선언으로 추가를 하는 역할을 합니다. json은 자바스크립트이기 때문에 페이지에 가져올 수 있습니다. daum검색은 output을 json으로 리턴이 되기 때문에 가능합니다.
그러면 json객체를 사용할 수 있습니다.
callback함수는 parseResponse입니다. 이 함수는 그냥 data부분에 json으로 받게 되는데 그것을 그냥 파싱만 해줘서 엘리먼트를 생성해서 results div에다가 엘리먼트를 추가하는 식으로 되어있습니다.

이상입니다 ^^

사용자 삽입 이미지

 
Posted by 머드초보
,