Creazy!

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

Bookmarklet 開発実績

TwitterでクリッピングするためのBookmarklet

投稿日:


いままで、ブログのURLや引用をTwitterにツイートするブックマークレットは何度か作っています。

上の2番目のエントリーでTwitter公式のBookmarkletを改造して使ったりしていたんだけど、大分前にメインブラウザをChromeに切り替えていて、Chromeでは動かないようだったのでサクっと書き直してみました。前は外部JSを呼び出す方式をとっていたんだけど、面倒なコードをいくつか捨ててワンライナーです。
Twitter Clip
↑のリンクをブックマークしてください。

  1. そのまま実行すると、見ているページの「タイトル t.co短縮URL」というフォーマットでTweetBoxが表示されます。
  2. ページ内を選択した状態で実行すると、「”引用部分” t.co短縮URL」というフォーマットでTweetBoxが表示されます。

前のブックマークレットでは文字数制限にかからないように切り捨てとかやってたんだけど、省きました。


ちなみに、スクリプトの中身を分かりやすく書くとこんな感じ。

javascript:
(function(){
var d=document,
w=window,
l=location,
e=encodeURIComponent,
s=(d.selection)?
d.selection.createRange().text:(w.getSelection)?
''+w.getSelection():(d.getSelection)?
d.getSelection():'',
t=!s?d.title:'%22'+s+'%22',
f='http://twitter.com/share?_='+(new Date()).getTime()+'&url'+e(l.href)+'&text='+e(t);
if(!w.open(f,'_blank'))l.href=f;
})();

t変数の部分がテキスト部分になります。ここを変更すればフォーマットを自由に変更できます。
例えば、文頭に必ずハッシュタグ(#clip)を入れたい場合は、

t='#clip '+(!s?d.title:'%22'+s+'%22'),

こんな感じにすればいいはず。
引用の場合もタイトルは入れたい場合、

t=!s?d.title:'%22'+s+'%22 '+d.title,

こんな感じかと。
Chrome、Firefoxではちゃんと動くと思いますが、多分IEでも動くと思います。
enjoy!

-Bookmarklet, 開発実績

執筆者:

関連記事

ツイポーート、リニューアル後1ヶ月の利用状況

GW前に「ツイポーート/twport」のversion3を公開してから、早くも1ヶ月経過しました。大幅なインターフェイス変更をしているので使って頂いている方たちの反応が気になっていましたが、ある意味予 …

no image

ページタイトルを取得するPipesを作りました

前に、こんなエントリーも書いているのですが、 ・PHPでWEBページのタイトルを抜き出すサンプル もっとお手軽にYahoo!Pipesで取得できるようにしてみました。 Pipes: getPageTi …

ブログの更新を自動通知する仕組みの違い Linkback/TrackBack/PingBack/RefBack

昨日トラックバックに代わる仕組みが欲しいと思って、サクッと「LinkBack.JS」なんてものをでっち上げたんですが、その中で@akkyさんからコメントで良い情報を頂きました。 Technoratiの …

no image

GYM Search を少し調整しました

少し前にGYM Searchというサービスを公開していました。 主要な検索エンジンとして知られている、Google、Yahoo!、MSN Live Search、から同時に検索結果を取得し一覧表示しま …

no image

SBM Common API (ver1.1) ブックマーク表示画面、追加画面のURLリダイレクターを追加

先日公開した、SBM Common APIに機能追加を行いました。 追加したのは、下記2つのURLリダイレクターになります。 3)各SBMのブックマーク表示画面のURLにリダイレクトするURL 4)各 …

スポンサードリンク

スポンサードリンク