最初に結論 / Chrome拡張「Enable right click」/ JavaScriptで、右クリック禁止を解除します

Webデザイン

カテゴリー: ブラウザ  閲覧数:611 配信日:2017-02-18 12:24


最初に結論


Webページの右クリック禁止を解除する「Chrome拡張」をインストールしても、コピペ出来るようにはなるとは限りません。

コピペ出来ないWebページをコピペ出来るようにするためには?
コピペ出来るようにする「ブックマークレット (Bookmarklet)」を作成します。

ブックマークレット とは?
userがWebブラウザのブックマークなどから起動し、Webブラウザで簡単な処理を行う簡易的なプログラムのことです。

Chrome拡張「Enable right click」


実際に試してみた「Chrome拡張」は、「Enable right click」

バージョン
0.0.9

更新日
2015 年 4 月 24 日

内容
右クリックが無効になっているサイトで右クリックメニューを有効にする

実際に試してみて気が付いたこと
・「右クリック禁止解除」=「コピペ出来るようになる」ではありません。
・両者は異なる概念です。
・「右クリック禁止解除」することでソースコードから「コピペ出来る」ようになります」が、はっきり言って面倒です。
・もっと手軽にコピペしたい、と思いました。

JavaScriptで、右クリック禁止を解除します


Chromeブラウザ下部で開く「Chrome Developer Tools」Consoleパネルへ、JavaScriptコードをコピペして実行

// 入れ替えるイベントリスナ
var f = function(){ return true; };

// 書き換え対象のDOMイベント名
var evs = "beforecopy beforecut click contextmenu copy dragstart mousedown mouseup selectstart".split(" ");

// 書き換え対象のCSS属性名
var props = "userSelect MozUserSelect MsUserSelect WebkitUserSelect".split(" ");

// 1要素に対する書き換え操作
function replace_events( elem ){
 // イベント
 for( var i = 0; i < evs.length; i ++ ){
   elem[ "on" + evs[i] ] = f();
 }
 // CSS属性
 if(elem.style){
   for( var i = 0; i < props.length; i ++ ){
      elem.style[  props[i] ] = "";
   }
 }
}

// 全要素に対し
var elems = document.getElementsByTagName("*");
for(var i = 0; i < elems.length; i ++){
 replace_events( elems[i] );
}
replace_events( document );


参考
ClipboardEvent

感想
・このJavaScriptコードを、Chromeブラウザ下部で開く「Chrome Developer Tools」Consoleパネルへ毎回コピペして実行することは、面倒だと感じました。
・もっと手軽にコピペしたいと思いました。

週間人気ページランキング / 3-3 → 3-9
順位 ページタイトル抜粋 アクセス数
1 「パッケージ化されてない拡張機能を読み込む」でインストールした拡張は、chromeを「更新」すると正常動作しなくなることがあります。 | Chrome 拡張機能 7
2 金融機関ブランドカラー / コーポレートカラー | カラーコード(色) 6
2 RGB ⇔ Lab | 色変換(色) 6
3 「Font Awesome 4」と「Font Awesome 5」の違い(Font Awesome バージョン4からのアップグレード) | Font Awesome(フォント) 5
3 このエントリーの結論 / 変更するまで /変更後 5
3 鉄道会社毎のカラーコード | カラーコード(色) 5
3 「東京都」のカラーコード取得は難しい | カラーコード(色) 5
4 色モデルイメージ図 | 色変換(色) 3
4 24ビットカラーにおけるHLS要素範囲 / 最小値 ~ 最大値 3
4 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない | モバイルデザイン(デザイン) 3
5 G'MIC | GIMP 系(ソフトウェア) 2
5 16進数カラーコード / 2進数 2
5 「bgcolor」「background-color」「background」の違い | CSS 2
5 「line-height」効果を打ち消すスタイルシートは、「line-height:normal; 2
5 「display:flex;」を設定している「
  • タグ」内の「タグ」クリック範囲を拡大する | Flexible Box Layout Module(CSS)
  • 2
    5 血の色 / #b30000 / #360800 / #ff0000 | カラーコード(色) 2
    5 FontAwesomeでアイコンが□(四角)になって表示されない Forbidden  | Font Awesome(フォント) 2
    6 「OOCSS」とは別の考え方? | 命名規則(コーディングルール) 1
    6 効果を打ち消すスタイルシート | CSS 1
    6 2系(Bootstrap) カテゴリー 1
    2025/3/10 1:01 更新
    指定期間人気ページランキング / 2020-5-30 → 2025-3-9
    順位 ページタイトル抜粋 アクセス数
    1 RGB ⇔ Lab | 色変換(色) 8523
    2 「マウスオーバー」「ロールオーバー」「ホバー」の違い | CSS 4532
    3 血の色 / #b30000 / #360800 / #ff0000 | 色 3682
    4 Design 0 3649
    5 Windows10で「Google Chrome」が常に最前面に表示される。「アクティブウィンドウ」が最前面で表示されない → 解決方法存在しない | Google Chrome(ブラウザ) 2663
    6 RGBの種類 / ビットカラー | RGB(色) 2609
    7 「bgcolor」「background-color」「background」の違い | CSS 1929
    8 金融機関ブランドカラー / コーポレートカラー | カラーコード(色) 1815
    9 16進数カラーコード / 2進数 1789
    10 コズミックブルーが何色か分からない | 色 1777
    11 「:hover」「z-index」を組み合わせて使用すると、正常動作しないことがある | z-index(CSS) 1633
    12 「Font Awesome 4」と「Font Awesome 5」の違い(Font Awesome バージョン4からのアップグレード) | Font Awesome(フォント) 1625
    13 「属性」「プロパティ」「アトリビュート」の違い | CSS 1580
    14 「Bootstrapデザイン」✕「グラフ」 | 2系(Bootstrap) 1500
    15 Chrome でキャッシュを効かさない | Google Chrome(ブラウザ) 1345
    16 「パッケージ化されてない拡張機能を読み込む」でインストールした拡張は、chromeを「更新」すると正常動作しなくなることがあります。 | Google Chrome(ブラウザ) 1304
    17 Chromeデベロッパーツールで、スマホソースコードを確認したいが、USBデバッグ機能をどうしても有効にすることが出来ない | モバイルデザイン(デザイン) 1168
    18 HSLとHSVの違い | 色変換(色) 1144
    19 「東京都」のカラーコード取得は難しい | 色 1065
    20 使用していないCSSをチェックする、標準的な方法を知りたい | CSS 1046
    2025/3/10 1:01 更新