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

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

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

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

JavaScript

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

Q&A

解決済

1回答

1452閲覧

vue.jsにてチェックカウント用変数の設置位置について

hololiveyukimin

総合スコア5

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

JavaScript

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

0グッド

0クリップ

投稿2021/06/10 08:18

編集2021/06/10 08:20

vue.js使用してWebアプリの開発を行っているのですが、カウント変数の設置位置がわかりません。
やりたいこととしては、チェックボックスのチェックオン・オフで削除ボタンのロック・ロック解除を繰り返すだけの簡単なものなのですが、dataに置くと以下のエラーが発生します。

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

ReferenceError: editCount is not defined

該当のソースコード

HTML

1<div class="uk-width-1-2 uk-algin-right"> 2 <label><input type="checkbox" class="uk-form" id="deleteCheck" name="check" v-on:change = "deleteCheck()">削除確認</label> 3 <button class="uk-button aoc_button_delete" v-on:click.prevent="deleteBtnClick()" id="delete" disabled = true ><i class="uk-icon-times"></i> 削除</button> 4</div> 5

JavaScript

1 2data:{ 3 //カウント用変数 4 editCount : 0, 5} 6methods : { 7/*------------------------------ 8 * 「削除チェック」チェック押下処理時( 9 *-----------------------------*/ 10 deleteCheck() { 11 target = document.getElementById("delete"); 12 editCount++ 13 if (editCount > 1) { 14 target.disabled = true; 15 editCount= 0 16 } else { 17 target.disabled = false; 18 editCount= 1 19 } 20 }, 21

試したこと

vue.jsの外側に置けば問題なく機能しますが、それは望ましい形ではありません。

補足情報(FW/ツールのバージョンなど)

開発環境 SpringBoot vue.js Uikit

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

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

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

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

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

guest

回答1

0

ベストアンサー

data配下なら「this.editCount」では?

投稿2021/06/10 08:22

sousuke

総合スコア3830

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

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

hololiveyukimin

2021/06/10 08:27

私の環境下ですと、data配下にthisは使えません。 試しにthis.editCount : 0,といれると 「この行に複数マーカーがあります - ',' が必要です。 - ':' を指定する必要があります。 - ':' を指定する必要があります。」 のエラーが発生します。
sousuke

2021/06/10 08:31

違います、 data:{ //カウント用変数 editCount : 0, } としているなら deleteCheck() { target = document.getElementById("delete"); this.editCount++ if (this.editCount > 1) { target.disabled = true; this.editCount= 0 } else { target.disabled = false; this.editCount= 1 } }, とする必要があるのでは?と言っています。 参照の方法がthis.editCountになるはずです。data内の定義方法ではないです。
hololiveyukimin

2021/06/10 08:36

返信ありがとうございます。 確認したところ、おっしゃる通りでした。 ほかのところにはthisをつけているのにここだけ付け忘れるというケアレスミスでした。 申し訳ありません。助かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問