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

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

ただいまの
回答率

91.06%

  • JavaScript

    13286questions

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

  • Stripe

    13questions

    Stripeとは、米国のオンライン決済システム提供企業、及び同社が提供する決裁システムを指します。Webサイトやモバイルアプリにコードを組み込むことでクレジットカードなどの決済サービスが簡潔に追加できます。

同一ページ内で<script></script>が複数存在する時の値の受け渡し方を教えていただけないでしょうか

解決済

回答 2

投稿

  • 評価
  • クリップ 1
  • VIEW 132

milkif

score 10

最初の<script>で値amountを取得出来ていることは確認しています。その後にstripe(決済システム)の埋め込みコードなんですが、script< タグ内に
コードが書かれているので、一つの<script></script>でくくれませんでした。
data-amount= に上記で取得した amount の値を渡す方法がわからず困っています。

<select id="amount" name="amount" onchange="myfunc()">
〜省略〜
</select>


<script>
  var amount;
  function myfunc() {
    amount = document.getElementById("amount").value;
    console.log(amount); //OK
  }
</script>
<script
  src="https://checkout.stripe.com/checkout.js" class="stripe-button"
  data-key="pk_test_XXXXXXXXXXXXXXXX"
  data-amount= amount
  〜省略〜
  data-currency="jpy">
</script>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • milkif

    2017/12/30 03:09

    先ほど投稿したですが表示されないので再送します。まずはご丁寧に対応いただき有難うございました。再読込とは onchangeイベントでその都度、変数amountを更新していることを再読込と書きました。イベントなどでdata-amountは更新できないんですね、なんとなく分かってきました。有難うございます。

    キャンセル

  • karamarimo

    2017/12/30 04:46

    正確には、data-amount という attribute を更新することは自由にできますが、たまたま checkout.js はロード時にしかその値をチェックしないということです。

    キャンセル

  • milkif

    2017/12/30 12:19

    やっと理解できました。ほんとうに丁寧なご対応有難うございました!

    キャンセル

回答 2

checkベストアンサー

+3

この custom の方法でやれば js 上で動的に料金などを指定できると思います。
Custom Integration - Stripe Checkout

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/12/30 12:38 編集

    正式な指定方法があったんですね。さっそく試してみました。
    <script>〜</script>内にfunction myfunc()を差し込んで amountにその変数を指定して期待通りに動きました。これで大掃除に取り掛かれます。本当にありがとうございました!

    キャンセル

+1

HTMLのタグで変数を使うことはできません。どうしてもやりたいなら、DOMの該当部分を直接生成するしかないでしょう。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/12/30 00:59

    アンサーありがとうございます。javascriptのやり取りだけで実現出来ると思いHTMLで質問させていただきましたが、ララベルのblade.phpで実装します。
    data-amount=<?php echo json_encode($amount) ?>で値の取得は確認できたのですが、 $amount(php) = amount(js) のようにjsの値をphpの変数には置き換えられなかったのでjs同士の受け渡しなら可能かと思ったのですがscriptタグを越えての値の受け渡しはできないんですね。

    キャンセル

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

  • ただいまの回答率 91.06%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • JavaScript

    13286questions

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

  • Stripe

    13questions

    Stripeとは、米国のオンライン決済システム提供企業、及び同社が提供する決裁システムを指します。Webサイトやモバイルアプリにコードを組み込むことでクレジットカードなどの決済サービスが簡潔に追加できます。