目次一覧
状態:-
閲覧数:2,465
投稿日:2017-02-18
更新日:2020-12-03
最初に結論 / Chrome拡張「Enable right click」/ JavaScriptで、右クリック禁止を解除します
「コピペ出来ないWebページをコピペ出来るようにする」ためのブックマークレットを作成 / 既存JavaScriptコードをブックマークレット化するためには?/ その他
→ 右クリック出来るのに、コピペ出来ないWebページ。2020 年
「コピペ出来ないWebページをコピペ出来るようにする」ためのブックマークレットを作成 / 既存JavaScriptコードをブックマークレット化するためには?/ その他
→ 右クリック出来るのに、コピペ出来ないWebページ。2020 年
最初に結論 / Chrome拡張「Enable right click」/ JavaScriptで、右クリック禁止を解除します
最初に結論
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パネルへ毎回コピペして実行することは、面倒だと感じました。
・もっと手軽にコピペしたいと思いました。
「コピペ出来ないWebページをコピペ出来るようにする」ためのブックマークレットを作成 / 既存JavaScriptコードをブックマークレット化するためには?/ その他
「コピペ出来ないWebページをコピペ出来るようにする」ためのブックマークレットを作成
ブックマークレット とは?
userがWebブラウザのブックマークなどから起動し、Webブラウザで簡単な処理を行う簡易的なプログラムのことです。
具体的には、1 行で書かれたJavascriptコードのことです。
リンクボタンのリンク先として、次のように書くと、クリックしたときにこのプログラムが実行できます。
javascript:実際のjavascriptコード処理;
既存JavaScriptコードをブックマークレット化するためには?
1.コメント削除
・Closure Compiler Service
2.JavaScriptのコードから行頭・行末のスペースと改行コードを取り除いて、ブックマークレットのアンカーを表示
ブックマークレット作成スクリプト
※事前にコメント削除しておかないと、正常動作しません。
3.Bookmarkletをボタンとして登録
ブックマークツールバーへ、リンクをドラッグ&ドロップで追加
※最初は意味が分かりませんでしたが、実際に試してみたら理解出来ました。
処理結果例
1.コメント削除
var f=function(){return!0},evs="beforecopy beforecut click contextmenu copy dragstart mousedown mouseup selectstart".split(" "),props=["userSelect","MozUserSelect","MsUserSelect","WebkitUserSelect"];function replace_events(b){for(var a=0;a<evs.length;a++)b["on"+evs[a]]=f();if(b.style)for(a=0;a<props.length;a++)b.style[props[a]]=""}for(var elems=document.getElementsByTagName("*"),i=0;i<elems.length;i++)replace_events(elems[i]);replace_events(document);
2.JavaScriptのコードから行頭・行末のスペースと改行コードを取り除いて、ブックマークレットのアンカーを表示
<a id="result_anchor" href='javascript:(function(){var f=function(){return!0},evs="beforecopy beforecut click contextmenu copy dragstart mousedown mouseup selectstart".split(" "),props=["userSelect","MozUserSelect","MsUserSelect","WebkitUserSelect"];function replace_events(b){for(var a=0;a<evs.length;a++)b["on"+evs[a]]=f();if(b.style)for(a=0;a<props.length;a++)b.style[props[a]]=""}for(var elems=document.getElementsByTagName("*"),i=0;i<elems.length;i++)replace_events(elems[i]);replace_events(document);})();'>コピペ</a>
その他
「Javascript」項目で「すべてのサイトに対してJavascriptの実行を許可しない」を選択し、完了をクリック
上記方法ではコピペ出来ません。
「テキストをコピーできないPDF」から「テキストをコピーする」ためには、「Chrome」で「印刷」選択後、保存