質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
URL

URL(ユニフォームリソースロケータ)とは、インターネット上のリソース(Webページや電子メールの宛先等)を特定するための形式的な記号の並びの事を言う。

パラメータ

関数やプログラム実行時に与える設定値をパラメータと呼びます。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

Q&A

1回答

1098閲覧

URLのパラメータを取得について

while--stu

総合スコア9

URL

URL(ユニフォームリソースロケータ)とは、インターネット上のリソース(Webページや電子メールの宛先等)を特定するための形式的な記号の並びの事を言う。

パラメータ

関数やプログラム実行時に与える設定値をパラメータと呼びます。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

コードレビュー

コードレビューは、ソフトウェア開発の一工程で、 ソースコードの検査を行い、開発工程で見過ごされた誤りを検出する事で、 ソフトウェア品質を高めるためのものです。

0グッド

0クリップ

投稿2020/01/22 06:50

編集2020/01/22 07:08

urlのパラメーターを取得する際に

var tString = getParam('t');はtから始まるパラメータを取得と理解できたのですが、
var t2String = getParam('t2');の箇所の意味が解りません。これは必要ですか?
教えてください。

document.addEventListener("DOMContentLoaded", function() { var el = document.createElement("script"); el.src = "https://static.landbot.io/landbot-widget/landbot-widget-1.0.0.js"; document.body.appendChild(el); // URLのパラメータを取得 function getParam(name, url) { if (!url) url = window.location.href; name = name.replace(/[[]]/g, "\$&"); var regex = new RegExp("[?&]" + name + "(=([^&#]*)|&|#|$)"), results = regex.exec(url); if (!results) return null; if (!results[2]) return ''; return decodeURIComponent(results[2].replace(/+/g, " ")); } var tString = getParam('t'); var t2String = getParam('t2'); if (tString == null) { document.querySelector('.js-copytext').innerHTML = 'エラーです'; } else { document.querySelector('.js-copytext').innerHTML = tString; } var copyEmailBtn = document.querySelector('.js-copybtn'); if (tString == null) { return false; } else { copyEmailBtn.addEventListener('click', function(event) { // .js-copytextのテキストを選択 var copyText = document.querySelector('.js-copytext'); var range = document.createRange(); range.selectNode(copyText); window.getSelection().addRange(range); try { // テキストを選択したらクリップボードにコピーする var cCode = document.querySelector('.js-copytext') var successful = document.execCommand('copy'); var msg = successful ? 'successful' : 'unsuccessful'; console.log('Copy command was ' + msg); alert('クーポンコードをコピーしました。'); } catch(err) { console.log('Oops, unable to copy'); } // 選択状態を解除する window.getSelection().removeAllRanges(); }); } });

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2020/01/22 06:55

なんでしょう「ぶん」って <タイトル
m.ts10806

2020/01/22 06:55

あと、自身が書いたコードではないのですか?出典も明示してください
guest

回答1

0

気になる関数はコードリーディングしましょう。ご質問の例では9行です。

javascript

1function getParam(name, url) { 2 if (!url) url = window.location.href; 3 name = name.replace(/[[]]/g, "\$&"); 4 var regex = new RegExp("[?&]" + name + "(=([^&#]*)|&|#|$)"), 5 results = regex.exec(url); 6 if (!results) return null; 7 if (!results[2]) return ''; 8 return decodeURIComponent(results[2].replace(/+/g, " ")); 9}

次に、関数に適当な値を入れて結果を確認します。

javascript

1console.log( getParam("t","http://example.com/?t=ValueOfT") ); 2// ValueOfT 3console.log( getParam("t2","http://example.com/?t2=ValueOfT2") ); 4// ValueOfT2 5console.log( getParam("t2","http://example.com/?t=ValueOfT&t2=ValueOfT2") ); 6// ValueOfT2

var tString = getParam('t');はtから始まるパラメータを取得と理解できたのですが

3つ目の結果から、「tから始まるパラメータ」という解釈が間違っています。

var t2String = getParam('t2');の箇所の意味が解りません。これは必要ですか?

必要性は getParam() の有効なスコープ内で t2String を使うかどうかで判断します。

投稿2020/01/22 23:11

AkitoshiManabe

総合スコア5432

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問