Creazy!

WEBエンジニア・ヤガーのテック・ガジェットブログ

Bookmarklet 小技集

見ているページのHTMLソースを表示するブックマークレット(Yahoo!Pipes版)

投稿日:


この辺のエントリーに触発されてブックマークレット作りました。
URLを渡すとページの内容(htmlソース)をJSONPとかで取得できるAPIをYahoo! Pipesで作った(管理人日記) – むぅもぉ.jp
Big Sky :: JSONでHTMLを取得するYahoo! Pipesが凄い
Show HTML Source
↑のリンクをブックマークしてください。


簡単に仕組みを紹介します。

指定されたURLのHTMLソースを返すPipesを作る

これは、前述のむぅもぉ.jpさんのほぼそのままコピーです。
http://pipes.yahoo.com/yager/page_loader
んで、これをJSONPで取得すればOK

ブックマークレットで呼ばれている外部JSの中身

http://labs.creazy.net/bookmarklet/pipes_show_source.js

/**
* show HTML source (powered by Yahoo!Pipes)
* @author takahito.yagami[at]gmail[dot]com
*/
/**
* callback function
* get HTML source from pipes, insert to DIV
*/
function __showSource(json) {
var html
= '<p style="text-align:right;margin:5px 10px 0 10px;padding:0;">'
+ '<a href="javascript:document.body.removeChild(document.getElementById(\'__source_viewer\'));void(0);">close</a>'
+ '</p>'
+ '<text'+'area style="margin:5px 10px 10px 10px;border:1px solid #000000;width:95%;height:85%;background:#FFFFFF;color:#000000;font:12px monospace;">'
+ json.value.items[0].content.replace(/</g,'<').replace(/>/g,'>')
+ '</text'+'area>';
document.getElementById('__source_viewer').innerHTML = html;
}
// prepare HTML source viewer
document.body.innerHTML
+= '<div id="__source_viewer" style="position:absolute;z-index:99999;top:5%;left:5%;width:90%;height:90%;background:#EEEEEE;">loading ...</di'+'v>';
window.scrollTo(0,0);
// call pipes
var s=document.createElement('script');
s.charset='UTF-8';
s.src='http://pipes.yahoo.com/yager/page_loader?_render=json&_callback=__showSource&url='+encodeURIComponent(location.href);
document.body.appendChild(s);

まあ、細かい説明はしないのでソース読んでもらうとして、
 ・表示用のdiv、textareaを作成
 ・pipesに今見ているページのurlをわたしてHTMLソースを受け取る
 ・textareaに流し込む
な感じの作りです。

使えないケース

Yahoo!PipesのFetch Pagesを使っているので、その辺りで制限事項があります。
 ・ログインが必要なページなどYahoo!Pipesから見えないページは表示できません。
 ・script, link など一部のメタタグは表示されません(Fetch Pagesの仕様らしい)
というわけで、誰かの役に立つでしょうか・・・。

動画を楽しもう!(Youtubeの動画を片っ端からダウンロードするブックマークレット)
EXIF情報を一覧表示するブックマークレット「EXIF EXISTS ?」を作りました
第13回:URLエンコードとURLデコードを簡単にするブックマークレット
第11回:引用(blockquote)を簡単にするブックマークレット
第9回:閲覧しているサイトへのリンクタグを生成するブックマークレット
第6回:TinyURL の遷移先が怖くて開けない場合の対処法

-Bookmarklet, 小技集

執筆者:


comment

メールアドレスが公開されることはありません。

関連記事

Raspberry Pi 4 Model B 8GBでライブ配信(1) USB接続のWEBカメラ映像をFFmpegで保存してみる

ブログご無沙汰しております。ヤガーです。 本業のWEB開発と並行して、リモートワーク推奨の影響でライブ配信などの需要が高まっており、以前よりイベントなどで配信をしていた関係で様々な形式でのライブ配信方 …

no image

blog chart.jp のブログパーツが重いので勝手に改造した

すでにローンチから時間が経ってしまっていますが、ブログを色々な角度から解析してチャート化してくれるWebサービス「blog chart.jp」というのがあります。 ABCDEFGの頭文字をもつ6つの指 …

動画を楽しもう!(Ustream.tvで録画した動画「Past Clips」のFLVをダウンロード可能にするブックマークレット)

【2012/01/03:更新】 Ust DLの公式ページができました。今後の最新情報はこちらをご確認ください。 Ust DL 公式ページ 【2010/04/13:追記】 スクリプトをアップデートしまし …

facebookのファンページを作る時に気をつけたい細かい話

何かと話題のfacebookですが、前回のエントリーではプロフィール画面で遊ぶ方法をとりあげました。で、今度はブロガーや企業の間でも増えてきているファンページの作り方について書いてみたいと思います。 …

屋外イベントでライブ配信と会場モニター映写した時の色々

このGWに自分が管理人として運営している千葉県富津市のローカルメディア富津っ子として、地元イベントのお手伝いをしてきたのですが、ちょっとテックよりな内容をこちらに記録しておこうと思います。 そのイベン …

スポンサードリンク

スポンサードリンク