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

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

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

HTTPにおけるCookieとは、クライアントのウェブブラウザ上に保存された一時的なデータを指します。クライアント側のJavaScriptでも、サーバー側のHTTPヘッダーでもクッキーの読み書き・修正・削除が可能です。

JavaScript

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

jQuery

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

Q&A

解決済

4回答

1794閲覧

サイト内の記事一覧で、それぞれの記事に「あとで読む」ボタンを作りたい

退会済みユーザー

退会済みユーザー

総合スコア0

Cookie

HTTPにおけるCookieとは、クライアントのウェブブラウザ上に保存された一時的なデータを指します。クライアント側のJavaScriptでも、サーバー側のHTTPヘッダーでもクッキーの読み書き・修正・削除が可能です。

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2017/06/12 12:34

編集2017/06/12 16:08

◯参考サイト(アダルトサイトです)
http://h-taikendan.net/

上記サイトのように、あとで見たい記事をボタンクリックして
一時的に保存したり削除したりするためにはどうしたらいいでしょうか。

おそらくjqueryとCookieを使用していると思うのですが、
どのようにコーディングしていいか分からず途方に暮れています。

◯実現したいこと
・DBを使わず動的にリンクの保存、削除。
・ひと目で保存した記事かどうか分かる。
・別ページで保存リンクの一覧を表示。

Googleでも調べてみたのですがヒットせず
こちらで質問させていただいた次第です…。

◯追記
教えていただいたloadStorageを使い、
色んなサイトを参考に、稚拙ながらがんばって作ってみました!
希望の動作になったのですが、2回目のクリックが効きません。
何か問題はありますか??

javascript

1$(document).ready(function() { 2 3 var ua = navigator.userAgent; 4 var isIE7 = ua.match(/msie [7.]/i); 5 6 $('.fav-add').click(function(){ 7 if(localStorage.getItem($(this).attr('url')) != undefined){ 8 localStorage.removeItem($(this).attr('url')); 9 10 $(this).fadeOut(null, function(){ 11 $(this).css('background-color', '#fafafa').fadeIn().unbind(); 12 }); 13 14 }else{ 15 localStorage.setItem($(this).attr('url'),$(this).attr('url')); 16 17 $(this).fadeOut(null, function(){ 18 $(this).css('background-color', 'red').fadeIn().unbind(); 19 }); 20 } 21 }); 22 23 var contentsList = document.getElementsByClassName("fav-add"); 24 25 for (var i = contentsList.length; i--;){ 26 27 if(contentsList[i].attributes.url.nodeValue == localStorage.getItem(contentsList[i].attributes.url.nodeValue)){ 28 contentsList[i].style.backgroundColor = "red"; 29 } 30 } 31 32});

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

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

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

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

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

guest

回答4

0

記事の識別子を
・セッション
・Cookie
・ローカルストレージ
・(ブラウザDB)
のいずれかに保存すれば実装できます。

この場合、保存先の判断は、保存する容量ですかねぇ。。。
上記を検索すれば、実装方法はいくらでも出てくるかと。

投稿2017/06/12 12:52

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

退会済みユーザー

退会済みユーザー

2017/06/12 13:37

なるほど…初耳な単語もあるので調べてみます! ご回答ありがとうございます!
guest

0

以下。具体的な実装はできるものとして説明します。できない場合は、回答にレスください。
【登録】
1.ページ内にボタンを定義
2.スクリプトで、おされたボタンに対応するURL、タイトルを取得しクッキーに保存する関数を定義
(保存期間と保存数を超えた場合の処理も合わせて実行)
3.1で定義したボタンに2で作成した関数を、clickイベントでバインド(スマホも利用する場合はタッチイベントとの分岐)
4.3.で追加した時点で、当該ページに履歴表示エリアがあれば、エリアを更新

【表示】
1.クッキーから登録で登録されたURL、タイトルの情報を基に表示エリアを作成
2.合致する記事であればボタンを変更

こんな考え方でいいんじゃないでしょうか。削除とかも上記をかえればやれるかと。

投稿2017/06/12 12:49

kanimaru

総合スコア1013

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

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

退会済みユーザー

退会済みユーザー

2017/06/12 13:32

ありがとうございます! なるほど…流れは理解できました! ただ、私の技術は「実装したい機能をネットで調べてスクリプトを改造」というレベルのため、 もしよろしければ、おヒマなときにでも簡単なサンプルコードを教えていただけると大変嬉しいです… ご回答ありがとうございます!
kanimaru

2017/06/12 15:45 編集

それだと、丸投げになってしまうので自分で学ぶか、お知り合いのプログラムができる方にお願いするか、いなければ、クラウドソーシングサービス等で料金を払って作ってもらうしかないかと・・・。w あくまでも、自分で努力する補助をする場だと私は思っております。お力添えできずにすみません。
退会済みユーザー

退会済みユーザー

2017/06/12 15:55

おっしゃる通りです…。 他の方に教えていただいたloadStorageを使い、 色んなサイトを参考に、稚拙ながらがんばって作ってみました! 質問本文に追記したので、見ていただけると幸いです! 希望の動作になったのですが、2回目のクリックが効きません。 何か問題はありますか??
guest

0

リンクが貼られていないため参考URLは見ていませんが、localStorage に保存したい表示ページのURLを保存すればできるのでは。

「ひと目で保存した記事かどうか分かる」はその記事ページで localStorage 内からその記事のURLを探し、あれば何か表示をすればよいでしょう。

【Window.localStorage - Web API インターフェイス | MDN】
https://developer.mozilla.org/ja/docs/Web/API/Window/localStorage

【localStorageで複数のデータを保存する | Tips Note by TAM】
https://www.tam-tam.co.jp/tipsnote/javascript/post5978.html

投稿2017/06/12 12:49

kei344

総合スコア69398

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

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

退会済みユーザー

退会済みユーザー

2017/06/12 13:35

ありがとうございます! loadStorage…そんな機能があるのですね! ただ、お恥ずかしい話ですが自分でゼロから作れる気がしません…。 似たようなことをしているサンプルスクリプトが掲載されているサイトなど ご存知でしたら教えていただけると幸いです…。 ご回答ありがとうございます!
kei344

2017/06/12 14:29

「localStorage JavaScript」で検索したら localStorage を使うサンプルはいくらでも見つかると思います。それを試した上で、わからないことがあれば新たに質問をされればよいと思います。 がんばってください!
退会済みユーザー

退会済みユーザー

2017/06/12 15:56

ありがとうございます! 教えていただいたloadStorageを使い、稚拙ながらがんばって作ってみました! 質問本文に追記したので、見ていただけると幸いです! 希望の動作になったのですが、2回目のクリックが効きません。 何か問題はありますか??
guest

0

ベストアンサー

$('.fav-add').click(function(){

上記を

$('.mainContentsListBox').on('click','.fav-add',function(){

に書き換えたら出来ました!
みなさんありがとうございました!

投稿2017/06/12 16:07

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問