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

解決済

回答 4

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 690

mamorist

score 13

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

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

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

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

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

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

$(document).ready(function() {

    var ua = navigator.userAgent;
    var isIE7 = ua.match(/msie [7.]/i);

    $('.fav-add').click(function(){
        if(localStorage.getItem($(this).attr('url')) != undefined){
            localStorage.removeItem($(this).attr('url'));

            $(this).fadeOut(null, function(){
                $(this).css('background-color', '#fafafa').fadeIn().unbind();
            });

        }else{
            localStorage.setItem($(this).attr('url'),$(this).attr('url'));

            $(this).fadeOut(null, function(){
                $(this).css('background-color', 'red').fadeIn().unbind();
            });
        }
    });

    var contentsList = document.getElementsByClassName("fav-add");

    for (var i = contentsList.length; i--;){

        if(contentsList[i].attributes.url.nodeValue == localStorage.getItem(contentsList[i].attributes.url.nodeValue)){
            contentsList[i].style.backgroundColor = "red";
        }
    }

});
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 4

+1

リンクが貼られていないため参考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 22:35

    ありがとうございます!

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

    ご回答ありがとうございます!

    キャンセル

  • 2017/06/12 23:29

    「localStorage JavaScript」で検索したら localStorage を使うサンプルはいくらでも見つかると思います。それを試した上で、わからないことがあれば新たに質問をされればよいと思います。

    がんばってください!

    キャンセル

  • 2017/06/13 00:56

    ありがとうございます!

    教えていただいたloadStorageを使い、稚拙ながらがんばって作ってみました!
    質問本文に追記したので、見ていただけると幸いです!

    希望の動作になったのですが、2回目のクリックが効きません。
    何か問題はありますか??

    キャンセル

+1

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

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

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

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/06/12 22:32

    ありがとうございます!
    なるほど…流れは理解できました!

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

    ご回答ありがとうございます!

    キャンセル

  • 2017/06/13 00:44 編集

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

    キャンセル

  • 2017/06/13 00:55

    おっしゃる通りです…。

    他の方に教えていただいたloadStorageを使い、
    色んなサイトを参考に、稚拙ながらがんばって作ってみました!
    質問本文に追記したので、見ていただけると幸いです!

    希望の動作になったのですが、2回目のクリックが効きません。
    何か問題はありますか??

    キャンセル

+1

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

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

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/06/12 22:37

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

    キャンセル

check解決した方法

0

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

上記を

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

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

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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