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

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

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

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

Q&A

解決済

2回答

3512閲覧

リンクを表示するにはどうすれば良いか。

destrudo

総合スコア143

JavaScript

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

0グッド

0クリップ

投稿2017/06/07 05:30

<html> <head> <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script> </head> <body> <script> var anchor = document.createElement("a"); anchor.id="link"; anchor.href=field.site_url; div.appendChild(anchor); var title = document.createElement("div"); title.id="title"; div.appendChild(title); $.getJSON("http://localhost/test/json_source.html",function(result){ $.each(result, function(i, field){ $("#title").append(field.title); $("#link").attr('href','field.site_url); }); }); </script> </body>
//jsonの構造 [{"title":"A","site_url":"X","使わない":"data"} {"title":"B","site_url:Y","使わない":"data2"} {"title":"C","site_url":"Z""使わない":"data3"}]

①anchor.href=field.site_url;というイメージでリンク先を
jsonデータのurlとして設定したいのですが、現状だと、
field is not definedと出て、まだ定義されていないので、
エラーになってしまいます。どうすればいいでしょうか?

②また、titleとlinkで一つの組み合わせにして、ループで表示したいのですが、aとdivでタグが違うため、
$( '#div_test' ).append( field.title + field.site_url);
のようにセットにすることが難しいと思いました。何か方法はあるでしょうか。今の状態だとtitleが全部表示されてから、urlが全部表示されるようになってしまいます。

どちらかわかる方教えてください。

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

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

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

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

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

guest

回答2

0

ベストアンサー

JavaScript

1$( '#div_test' ).append( '<a href="' + field.site_url + '">' + field.title + '</a>' );

投稿2017/06/07 05:46

kei344

総合スコア69400

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

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

0

① まだ定義されていないので、エラーになってしまいます。どうすればいいでしょうか?

とりあえず、""にしておいてはいかがでしょう?

② 今の状態だとtitleが全部表示されてから、urlが全部表示されるようになってしまいます。

ご質問を理解できているか不安ですが、a要素に.text()メソッドでテキストを入れればいいかと思います。

set the text contents of the matched elements.

.text() | jQuery API Documentation

投稿2017/06/07 05:57

Lhankor_Mhy

総合スコア36074

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問