08 | 2017/09 |  10

  1. 無料サーバー

User forum-FC2BLOG-Info-Edit Template-Post-Edit-Upload-LogOut

CSSやJavascript自習の苦闘史を綴っていきたい。恐縮ですがJavascriptを有効にしてご覧ください。
2005年12月から社会問題も掲載!

スポンサーサイト

上記の広告は1ヶ月以上更新のないブログに表示されています。
新しい記事を書く事で広告が消せます。

 

コメントフッター部のURL入力有無に関して(2)DOM版Javascriptによって操作する

 戴いたコメント下部の URL 文字をクリックした際の動作を、既述の方法から改善した。

commentfooter.jpg


 これは、phpbbの過去の質疑応答に掲載されている daniel さんの素晴らしい回答を参考にさせていただき、かつHTML文の中にJavascriptを埋め込む方法ではなく、外部ファイル内に必要なスクリプトを書いて、同等の結果を得たものである。daniel さんへの深甚の感謝と共に、自ら作成した既述の方法よりも遙かにスマートになったことを喜びたい。
 先の方法による「alert表示」はそれを消すユーザー操作を一行程増やしていたが、今回の方法はalertは不要である。Aタグが残っている限り、そのhref属性値つまりurlアドレスが入力されていなければ、blank頁が表示されてしまう。これが今回のスクリプトの最大の難関だったのだが、URL文字の上に mouseover になった時点で、Aタグを削除してしまうというDOMならばこそ可能となる手法によって、空頁の展開を避けることに成功したのだ。
 そこで少しくスクリプトについて解説しておくことも無駄ではないだろう。


■HTML部────────────
 コメント下部の「URL |」部分のHTMLは次のようになっている。
(説明用に適当に改行したが、DOMによるコントロールのためには中間の改行は邪魔なだけで、実際のテンプでは中間の改行は一切ない。また、アンダーラインと文字の着色も説明用であり、実際のテンプではこれらの装飾もない。)


●テンプレート───
<li onmouseover="removeA(this)">
<a href="<%comment_url>" target="_blank"
title="<%comment_url>">URL</a>
 | </li>


●Javascriptによる対応後(URLが未入力のコメントの場合)───
 URLの文字上でonmouseoverになるとJavascript関数removeA(this)が起動して、Aタグを削除してしまうようにした。
 Aタグ削除後の当該部HTML文は以下のように変化する。
<li onmouseover="removeA(this)">URL | </li>
 ※ URLが入力されている場合にはHTML文はテンプレートのまま、何も変化させない。


■Javascript部────────────
  //Aタグを削除する関数
function removeA(which) { //whichで当該のliタグを取得
  //hrefの属性値つまりリンク先URIを取得
 uristr = which.firstChild.href;
  //liの第一子Aのリンク属性値が空またはnull値だったら
 if (uristr == null || uristr =="") return false;
  //リンク属性値がMyblogURIでなければ、つまりコメント投稿者のURIであれば何もせずに関数を終え、既定のAタグを有効にする。
 if (uristr.indexOf("http://hkom",0) < 0) return;
  //リンク属性値がMyblogURIならばAタグを削除する。(URI未入力時には何故かmybloguriが挿入されるため)
 else {
   //「URL」というテキストノードを作成
  uristr = document.createTextNode('URL');
   //「 | 」テキストノードの前にURLテキストノードを挿入
  which.insertBefore(uristr,which.childNodes[1]);
   //Aタグ(<a href=・・・/a>)を削除
  which.removeChild(which.childNodes[0]);
 }
}

 

■ コメントの投稿 ■

管理者にだけ表示を許可する

●トラックバック●

■トラックバックURLはこちら■
http://hkom.blog1.fc2.com/tb.php/201-4b3c3e11

●参照元一覧●

<provided Fc2>
<provided i2i>

▲ToTop

 90%近いシェアを握っているインターネットエクスプローラの描画エンジンを利用したタブbrowser。沢山のタブbrowserがあるが、多機能、カスタマイズフリー、スクリプト利用等で一日の長がある。Gekkoエンジンへの対応も行われ、IEからの自立独立の方向に向かっている。2005年7月にはIE7が登場する見通しの中で、今後の発展が望まれる。

 多様なCSS作成支援機能を備えた、タグ入力式 HTML&CSS作成支援エディタ。スキンデザインもすっきりしている。テキストエディター上で作成するよりも確実で安全にタグ打ちが出来る。
文字コードを選べないのが欠点。

 StyleNote同様のタグ入力式 HTML&CSS 作成支援エディタ。長年使用してきたが現在StyleNoteに乗り換えつつある。

 クリップボード履歴情報を活用する為のソフト。画像まで履歴を取ってくれるのが嬉しい。このソフトを使わない日は絶対ない程に重宝し、愛用している。

 起動中のウィンドウの「コピーできない」説明文などの文字列を取得し、コピー可能な文字データにするツール。何かと便利。

 ストリーミングデータを保存することが出来るソフト。動画利用には不可欠なソフトだ。

 無料ながらレイヤー機能を有し、スクリプトによる拡張も可能な、sleipnir作者が提供している優れもの画像編集ソフト。

 画面キャプチャソフトと言えばこれに勝るものなし、ではないだろうか? 様々な取得方法を有しており、ブログ作成にもHomepage作成に不可欠だ。Jtrimと並んでWoodyBellsの作品。

 複数ファイルの同時編集は出来ないが、透過pngも作れる画像編集ソフト。
(以下当該サイトから抜粋)初心者にも簡単に操作が出来るフォトレタッチソフトです。多くの加工機能で画像に様々な効果を与えることができます。非常に軽快に動作するため、ストレスなく操作できます。

 Animation Gifファイルを作れる無料ソフト。

 キャプチャソフト。画面内にサイト全体が表示しきれない場合でも、これを使えば全体をキャプチャすることが出来る。

 画像処理。画像のフォーマット変換のみならず、色数やサイズ、圧縮率の変更まで一括処理できてしまう『BatchGOO!』は、大量の画像をまとめて処理したいときに大変便利なソフト。BMP, TIFF, JPEG, PCX, PNG の相互変換をはじめ、色数・サイズ・解像度の統一、JPEG圧縮率の調節など、ホームページ用の画像や携帯電話用の壁紙を揃えるのに抜群の相性を見せる。(Vectorの当該ソフト紹介頁より抜粋引用)

 名前から直ぐに想像が付くように画像のサイズを測るためのソフトだ。Homepage作成には欠かせない。2カラム、3カラムのレイアウトを行う場合に大変重宝する。

 ランチャーソフトは沢山あるが、中でもこれが一押しだ。2年以上使ってきたがその操作性には毎日満足している。これを使い始めてからデスクトップには一切のアイコンを表示することをやめてしまった。

 AdobeReader7によって、起動時間が長すぎるという長年のユーザーの不満はある程度解消した。そのためこの高速化ソフトは存在価値が低下してしまったかもしれない。AdobeReader6迄はこのソフトによる起動高速化で恩恵を受けてきた。

 IE専用が難点だが、様々なサイト内でIDやパスワードを入力するのに重宝するソフト。コンテキストメニューから簡単に起動できるのがGood! sleipnir等のIEの描画エンジンを利用しているブラウザでも使える。

 利用しているパソコンの諸元値を取得するには、このソフトがベストだ。インストール済みソフトの一覧が取得できるのも嬉しい。

 WMPは機能が豊富なだけ重い。RealPlayerも同様だ。そこでMedia Player Classicを使いたい。動作が軽快なだけではなく、対応しているファイル形式もすこぶる多く、これひとつで、wmvもrmも表示できてしまうのだから凄い! 数多あるMedia Playerの王様と言えるだろう。

 自宅でPCを起動しているときには必ず起動しているメディアプレーヤー。何かと過剰なWinampよりも、起動も速くスキンはシンプルだ。

 DivX, Xvid, Mov, Vob, Mpeg, Mpeg4, avi, wmv, dv, などの動画をDVD-Video形式に変換できるフリーソフト。クリックするとDVD関連ソフト紹介サイト=「DVDなToolたち」なるHomepageが開きます。

----------
200505281127
上記広告は1ヶ月以上更新のないブログに表示されています。新しい記事を書くことで広告を消せます。