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

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

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

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

Q&A

解決済

3回答

660閲覧

JavaScript location.hrefのリンクについて、もっと綺麗な記述方法があれば教えてください。

rastynail3366

総合スコア6

JavaScript

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

0グッド

0クリップ

投稿2020/10/23 00:54

編集2020/10/23 00:57

現在絶対パスを取得してリンクをするために以下の記述をしています。

HTML

1//https://HostName/DirectoryName/Index?year=2020&month=10 を起点にして 2//https://HostName/DirectoryName/Create?year=2020&month=10&id=nに遷移する 3var pathnames = location.pathname.split('/'); 4var pathname = ""; 5for (var j = 0; j < pathnameList.length; j++) { 6 if (pathnames[j].indexOf("Index") === -1) { 7 pathname += pathnames[j] + "/"; 8 } 9} 10var url = location.origin + pathname + "/Create" + location.search + "&id=" + id; 11location.href = url;

現在リンクのために8行も使っているのですが、もっと短く記述できる方法があれば知りたいです。

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

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

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

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

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

guest

回答3

0

単純に/Index/Createに置換して&id=nをつければ良いかと思いますが、ホスト名やディレクトリ名が仮のものなので提示のものが汎用性も高いのでは。短く書けばいいってものでもないです。
パターンケースによって要件を満たせるかどうかを主眼としてください。

投稿2020/10/23 01:01

m.ts10806

総合スコア80875

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

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

0

ベストアンサー

現在リンクのために8行も使っているのですが

pathname が絡むと、ある程度行数は必要です(それをユーザ関数にして使えば、各所で1行になります)。

requirejs というAMDに分類される「モジュール化ライブラリ」でも、pathname 処理用のユーティリティ関数trimDots() が実装されていますが、17行です(うまく使えば NodeJS の url.resolve() などをブラウザ側で実装できそうな強力なpathname処理を行います)。

モダンブラウザでのURLの処理は、次のネイティブ実装も参考にして良いと思います。

投稿2020/10/23 01:49

編集2020/10/23 01:53
AkitoshiManabe

総合スコア5434

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

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

0

どこまで汎用性を求めているかによりますが

javascript

1var orgurl="https://HostName/DirectoryName/Index?year=2020&month=10"; 2var newurl=orgurl.match(/.+//)[0]+"Create"+orgurl.match(/?.+/)[0]+"&id=n"; 3console.log(newurl);

投稿2020/10/23 01:11

yambejp

総合スコア116724

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問