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

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

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

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

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

2回答

2690閲覧

Vue.jsのセレクターはあるのでしょうか?

teratailmacr2

総合スコア31

Vue.js

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

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2020/10/13 09:47

jqueryはVue.jsに置き換えられると色んな場所で見かけます。
(早い話がjqueryはオワコンだと)

場合によっては置き換えも可能かもしれませんが、それぞれの目的や内容が異なりますので、本来同列に考える事に無理がある気がします。

例えば、jqueryは素のjavascriptよりもセレクターが優れており、短い記述で直感的に対象物を選択出来ると思いますが、jqueryなしでVue.jsで同じ様な事が出来るのでしょうか?

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

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

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

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

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

guest

回答2

0

ベストアンサー

対象のDOMを取得するということでしたら、refを使用することで取得が可能です。

例えば、jQueryでは下記のような書き方で、DOMを取得するかと思います。

<div id='test' /> console.log($('#test')) -> id='test'を取得

これをVueに書き直すと下記のようになります。

vue

1<template> 2 <div ref='test' /> 3</template> 4 5<script> 6 mounted () { 7 console.log(this.$refs.test) -> ref='test'を指定したdivの要素が取得できる 8 } 9</script>

投稿2020/10/13 13:13

編集2020/10/14 09:42
stakizawa

総合スコア117

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

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

teratailmacr2

2020/10/14 08:14

ご回答ありがとうございます。 なるほど、「<input type="text" name="age" ref="age" value="20">」も「this.$refs.age.value」とする事で値が取得出来るのですね。 ただこれだとjqueryで言うところの$('#age')と同等だと思いますが、#age直下のliの三番目とかそう言った取得方法も可能なのでしょうか?
stakizawa

2020/10/14 09:53

> なるほど、「<input type="text" name="age" ref="age" value="20">」も「this.$refs.age.value」とする事で値が取得出来るのですね。 もちろん可能です。 ただ上記の例の<input>の場合、Vue.jsではv-modelというディレクティブを使用して、dataと紐づける方法の方がいいかと思います。 具体的には、下記のようなコードになります。 <input v-model='test' /> // vue data: () => ({ test: '' <- このプロパティとv-modelがリンクする }) こうすることで、ユーザーがinputに対して、入力した際にtestプロパティに値が入ります。 これは、入力するたびに動的におきかわります。 // testプロパティへのアクセス console.log(this.test) -> ユーザーが入力した値 > ただこれだとjqueryで言うところの$('#age')と同等だと思いますが、#age直下のliの三番目とかそう言った取得方法も可能なのでしょうか? これに関しては、v-forを使用した場合には、アクセス可能になります。 (もしかしたら、別でやり方はあるかもしれませんが...) 長くなってしまうので、ここでの解説は控えさせていただきます。 また、個人的な意見になってしまい申し訳ないのですが、基本的にVue.jsで直接DOMを参照する機会はほとんどないかと思います。
teratailmacr2

2020/10/16 01:43

遅くなりましたがご回答ありがとうございます。 なるほど、予め必要なエレメントの値をモデル化しておくと取得出来ると言う事ですね。 jqeuryの様に動的に作り出されたものに対して、値が何であったら、action1、違えばaction2みたな事をしたい場合、やはりvue.jsの範疇ではない為対応は難しいのでしょうか? その様な事がしたい場合は、やはりjqueryを使った方が良いのでしょうか?
stakizawa

2020/10/16 02:10

> jqeuryの様に動的に作り出されたものに対して、 すいません。jqueryで動的に作り出されたものというのは、具体的にどのようなものでしょうか? DOMの作成・削除のことを指していますかね?? > 値が何であったら、action1、違えばaction2みたな事をしたい場合、やはりvue.jsの範疇ではない為対応は難しいのでしょうか? 値の変更を監視するには、watchというものを使用することが出来ますね。 (データのモデル化は必要ですが...) watchでは、変更前と変更後の値を取得できるので、それを元に処理をすることも可能です。 teratailmacr2さんの望んでいる回答が出来ているか不安ではありますが...
teratailmacr2

2020/10/17 04:10

ご回答ありがとうございます。 > DOMの作成・削除のことを指していますかね?? そうです。 例えば、createElementで<input type="text">を3つ作ったとして、この3つに入力された数値の合計が15を超えていれば4つめ以上を作らせず、超えていなければ4つめ以上も作成可能としたい場合等、入力欄を動的に生成しているので、Model化が出来ない(?)場合はjqueryでしか対応出来ないでしょうか? stakizawaさんのご回答は質問に対して的確なご回答をいただけております。 お手数ですが、引き続きご教示いただけましたら幸いです。
guest

0

jqueryは素のjavascriptよりもセレクターが優れており、短い記述で直感的に対象物を選択出来ると思いますが、jqueryなしでVue.jsで同じ様な事が出来るのでしょうか?

それはVue.jsの用途ではありません。

投稿2020/10/13 09:49

maisumakun

総合スコア145208

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

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

maisumakun

2020/10/13 09:50

すでにHTMLでできあがったページを書き換える、という場合はVue.jsの出番では基本的にありません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問