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

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

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

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

Q&A

解決済

2回答

5891閲覧

Javascriptで属性値を設定したい

kozy

総合スコア20

JavaScript

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

0グッド

0クリップ

投稿2017/05/18 04:39

###前提・実現したいこと
Javascriptを勉強中のものです。getAttribute()/setAttribute()を使って属性値を設定したいのですが、
上手くいきません。取得はできているのですが、その値を設定するところでエラーが出てしまいます。
(なぜvalが未定義になってしまうのかが分かりません)。
下記のコードで修正するべきところをご指摘いただければありがたいです。

よろしくお願いいたします。

###発生している問題・エラーメッセージ

エラーメッセージ test.html:27 Uncaught ReferenceError: val is not defined at HTMLInputElement.<anonymous>

###該当のソースコード

<!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <title>属性の取得/設定</title> </head> <body> <form> <a href="https://www.yahoo.co.jp/" id="first_a"></a><hr> <input type="button" id="getBtn" value="取得"> <input type="button" id="setBtn" value="設定"> </form> <a href="#" id="second_a"></a> <script> window.addEventListener('load', function(){ var link1 = document.getElementById('first_a'); var link2 = document.getElementById('second_a'); document.getElementById('getBtn').addEventListener('click', function(){ var val = link1.getAttribute('href'); //console.log(val); }); document.getElementById('setBtn').addEventListener('click', function(){ link2.setAttribute('href', val); }); }); </script> </body> </html>

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

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

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

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

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

guest

回答2

0

Javascript

1 2document.getElementById('getBtn').addEventListener('click', function(){ 3 var val = link1.getAttribute('href'); // ※1 4 //console.log(val); 5}); 6 7document.getElementById('setBtn').addEventListener('click', function(){ 8 link2.setAttribute('href', val); // ※2 9}); 10

※1valを**※2**は知りません。スコープが一致していません。
var valvar link2と同じ階層で宣言している必要があります。

投稿2017/05/18 04:46

honami

総合スコア308

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

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

kozy

2017/05/18 05:23

素早いご回答ありがとうございました! 無事解決いたしました。
guest

0

ベストアンサー

JavaScript のスコープを理解する

↑ ご参照ください。

val という変数が

function(){ var val = link1.getAttribute('href'); //console.log(val); });

この関数の内部で定義されている為ですね。

外部に出して、

var link1 = document.getElementById('first_a'); var link2 = document.getElementById('second_a'); var val;

以下のようにすれば、一先ず、エラーが出なくなりますよ。

function(){ val = link1.getAttribute('href'); });

投稿2017/05/18 04:49

Ikkitang

総合スコア34

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

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

kozy

2017/05/18 05:23

素早いご回答ありがとうございます! スコープを見落としておりました。 上記のようにしたら無事属性設定できました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問