簡単な記述でアサマシ

アサマシするにははてなダイアリーのisbn/asin記法が最強。比較的環境を選ばずに、ああいったソラでも打てるフォーマットでアサマシできれば良さそうだなというわけで作ってみた。面倒かなとか思ったけど、助言が多かったので結構簡単だった。

結果として、複数のアサマシも可能だとかそんな感じのサンプルが出来上がった。アクション!

具体的には、アサマシHTMLコードを挿入したい場所に、

<script type="text/javascript"
  src="http://example.com/asamashi.js#{ASINコード}"></script>

こんな感じできれば良いかなというイメージで考え始めた。

script要素のsrc属性に記述されたJavaScriptファイルのURLに引数を付けて実現している。引数の取得の方法はscript.aculo.usの動的ロードの仕組みから。script.aculo.usがそういったテクニックを使っていることはまららんに教えて貰った。簡単に説明すると、

ということ。これで上記のような記述でASINコードが拾える。ちょっとしたコードの追加ではてなのisbn/asin記法のようなdetailとかimageみたいなのに対応するのも簡単そう。

与えられたASINコードのデータを取得しHTMLにするのは、labs.hail2u.net/amazon/なんかと一緒なので割愛。

書き出しはdocument.writeだとHTML全体が置き換わってしまったので、このままではムリ。これもまららんの助言で記述を、

<script type="text/javascript"
  src="http://example.com/asamashi.js#{ASINコード}"></script>
<div id="asamashi-{ASINコード}"></div>

として、挿入すべき場所を明示してやることにした。これでdocument.getElementById('asamashi-{ASINコード}').innerHTMLにぶち込むだけということになる。

簡単な記法と言っても結構打つのはツライとかいう。ASINコード以外をIMEの辞書に「アサマシ」とでも登録すれば楽かも?

追記

この機能を実際に利用するには、asamashi.jsを入手した上で自分のアソシエイトIDに書き換え(できればAccess Key IDも)てどこかにアップロードする必要があるなど、ちょっと色々ある。今のところ誰でも使えるようには作ってない(prototype.jsに依存してたりとか自前の変なライブラリに依存してたりとか)ので、もし使ってみようかなとか改造してみようかなとか思った人は、気をつけること。