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

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

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

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

633閲覧

画像一覧から個別ページに飛びたい

yaise

総合スコア1

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

2クリップ

投稿2021/11/05 16:43

編集2021/11/06 02:32

前提・実現したいこと

ショッピングサイトのようなものを作成しているのですが、
商品画像をクリックすると個別ページに飛び、その画像にあった画像とテキストを表示したいです。
そこでデータベースを使わずに、jsなどで画像やテキストを保持しておいて、クリックイベントでその画像をクリックすると個別ページが完成されるようなシステムを作りたいのですが、可能でしょうか?

追記
デモサイトのようなものを作っており、実際に商品を管理してるわけではありません。

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

エラーメッセージ

該当のソースコード

html

最初のページ(index.html)※ここでは画像一つですが、実際は何個も画像があります。

<a href="goods.html"><img src="https://www.ikea.com/jp/ja/images/products/lack-coffee-table-black-brown__57537_pe163119_s5.jpg?f=s"></a>

遷移先のページ(goods.html)

<div class="goods"> <div class="goods-image" id="goodsImage"> <img id="img"> </div> <div class="goods-text" id="goodsText"> <p id="name"></p> <p id="price"></p> <p id="content"></p> </div> </div>

js

class ClickImage {
constructor(image, name, price, content) {
this.image = image;
this.name = name;
this.price = price;
this.content = content;
}
click() {
const goodsImage = document.getElementById('goodsImage');
const goodsText = document.getElementById('goodsText');
const img = document.getElementById('img');
const name = document.getElementById('name');
const price = document.getElementById('price');
const content = document.getElementById('content');
img.src = this.image;
name.textContent = this.name;
price.textContent = this.price;
content.textContent = this.content;
}
}

const clickImage = new ClickImage("https://www.ikea.com/jp/ja/images/products/lack-coffee-table-black-brown__57537_pe163119_s5.jpg?f=s", "椅子", "10000円", "tetetetetetetetet");
const clickImage1 = new ClickImage("https://img.tabroom.jp/img/brand/brd00308/itm0028275/is4_5c7623eab5f02bde8749c2a1f4e48536.jpg", "椅子", "5000円", "tetetetetetetetet");

試したこと

index.html上でimgタグにonclick="clickImage.click()"など試してみたが、遷移先のページでは、何も表示されませんでした。

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

ここにより詳細な情報を記載してください。

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

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

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

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

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

m.ts10806

2021/11/05 22:48

そもそもどのように商品を管理しているのでしょうか。
guest

回答1

0

ベストアンサー

JavaScript はページ単位でしか動かないです。
リンクなどによってページを移動すると、前のページのJavaScriptの実行は中止され新しい環境になるので、定義した変数や関数などもすべて捨てられます。

ですので、ページ間で動作を共同させようとするのであれば、何らかの方法でその情報を次のページに伝えなくてはいけないです。
サーバを使わずにこれを行いたいのであれば、フラグメントなどでURLに埋めるか、cookieなどのローカルストレージを利用するぐらいしか方法はないでしょう。

フラグメント | ウェブ上のリソースの識別 - HTTP | MDN

Window.localStorage - Web API | MDN


なお、ご存知かと思いますが、決済をローカルだけで実現するのは無理なので、外部サービスに頼らない限りこれでできるのはあくまで「ショッピングサイトのようなもの」であって、ショッピングサイトを作ることはできません。念のため。

投稿2021/11/06 00:34

編集2021/11/06 00:44
Lhankor_Mhy

総合スコア36163

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

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

yaise

2021/11/06 02:43

やはり厳しいですよね。 ご回答ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問