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

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

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

CoffeeScriptはプログラミング言語です。シンタックスシュガーの導入により、JavaScriptのコードに変換された後動作します。JavaScriptに比べ、可読性と簡潔性が向上しています。

jQuery

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

Q&A

解決済

1回答

913閲覧

CoffeeScriptで、一部クラスのみ対象外にする記法

neoz

総合スコア31

CoffeeScript

CoffeeScriptはプログラミング言語です。シンタックスシュガーの導入により、JavaScriptのコードに変換された後動作します。JavaScriptに比べ、可読性と簡潔性が向上しています。

jQuery

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

0グッド

0クリップ

投稿2021/03/01 02:08

CoffeeScriptで、一部クラスのみ対象外にする記法を教えて下さい。
jQueryでは情報が見つかったのですが、CoffeeScriptに関しては出てこず困っております。

例えば、このようにclassesをクリックするとsomeFuncが発動する場合で、
このうち、c-class以下にあるc-class-noincludeクラスを除外するにはどのように記述すれば良いでしょうか?

classes = '.a-class, .b-class, .c-class' $('something').on 'click', classes, (e) ->   someFunc()

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

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

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

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

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

maisumakun

2021/03/01 04:43

> jQueryでは情報が見つかったのですが どのようなものでしたでしょうか?
neoz

2021/03/01 04:48

こちらを参考にしましたが、仮にdivの当該classを除外という記法にしてもNGでした。 もしかすると、今回class指定がcoffee script方式で特殊だからでしょうか? https://teratail.com/questions/29945
guest

回答1

0

ベストアンサー

jQueryでは情報が見つかったのですが、CoffeeScriptに関しては出てこず困っております。

CoffeeScriptを使っても、jQuery部分については何も変わりません。jQuery+JavaScriptで書いたコードのJavaScriptを、そのままCoffeeScriptに書き換えればいいだけです。

投稿2021/03/01 02:13

maisumakun

総合スコア145184

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

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

maisumakun

2021/03/01 02:15

質問文にご提示のコードも、CoffeeScript+jQueryのコードのようです。
neoz

2021/03/01 04:37

ありがとうございます。jQueryなら調べてわかったつもりだったのですが、やってみると動かないので間違っているかもしれません。 $('body').not('.c-class-noinclude')とするとあったのですが、うまくいきません。
maisumakun

2021/03/01 04:43 編集

> $('body').not('.c-class-noinclude')とするとあったのですが、うまくいきません。 それは、「bodyにc-class-noincludeというクラスが付いていたら空のjQueryオブジェクト、そうでなければbody要素を含んだjQueryオブジェクト」という意味になります(JavaScriptでもCoffeeScriptでも変わりません)。
maisumakun

2021/03/01 04:52 編集

> もしかすると、今回class指定がcoffee script方式で特殊だからでしょうか? 違います。JavaScriptかCoffeeScriptかとは無関係です。 .onでイベントを拾う場合、条件は「セレクタ文字列1つ」でしか適用できません(.notのようなものを使う余地はありません)。適用する条件をどうにかセレクタ1本で表すか、セレクタ自体は広めにしておいてイベントハンドラ内部で改めて条件分岐するか、そのどちらかになります。
neoz

2021/03/01 06:02

あるclassの一部をクリックしたときだけ反応してほしくないので、イベントハンドラ内部で改めて条件分岐になるかと思います。 if $('div').hasClass('.c-class-noinclude')で条件分岐してみましたが、これだと常にtrueになる気がしてきました。今回の場合だと、どう分岐させるべきでしょうか…
neoz

2021/03/02 06:26

今回のケースで必要な動作要件を再定義してif文を作って解決しました。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問