0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

動的に背景画像を変更する(Ruby on rails,JavaScript)

Last updated at Posted at 2020-03-06

#はじめに
画像アドレスを入力することで、
背景画像を動的に変更する方法について書いていきます
#実行
基本となるビューファイルは次のようにします。

wall.haml.html
.body
  = text_area "object_name", {class: "wall-url"},{id: "wall-url"} 
  .wall-btn 画像を変える 

texr_areaが画像アドレスを張り付ける部分で、.wall-btnを押したら画像を変わるものとします。

次にJavaScriptです。(jQueryで書いています)

wall.js
$(function(){
  $(".wall-btn").on("click",function(){ 
  }) 
});

これで、.wall-btnをクリックした時に発火する関数ができました。
次は、処理の内容を書いていきます。

wall.js
$(function(){
  $(".wall-btn").on("click",function(){ 
    var image = $("#wall-url").val(); 
  }) 
});

これでテキストエリアに入力された画像アドレスを取得し、変数imageに代入できます。
テキストエリアのidwall-urlとなっているので、#wall-urlの中身を取得するようにすればよいわけです。

最後に、背景画像を取得した画像アドレスのものに変更します。

wall.js
$(function(){
  $(".wall-btn").on("click",function(){ 
    var image = $("#wall-url").val(); 
    $(".body").css('backgroundImage',`url("${image}")`); 
  }) 
});

注意するところは、background-imageを変更する処理ですが、
ここではbackgroundImageとなっているところです。
-がなくなって、直後の文字が大文字になっているわけですね。

url("${image}")の部分は、''で囲むと${image}がただの文字列と表示されるので、この表記にしています。
また、url(${image})としてもエラーになるので、必ず""をつける必要があります。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?