How to create an anchor and redirect to this specific anchor in Ruby on Rails

后端 未结 6 1109
爱一瞬间的悲伤
爱一瞬间的悲伤 2020-12-05 17:04

I\'m trying to create unique anchors for every comment on my blog so a person can take the url of an anchor and paste it in their browser, which will automatically load the

相关标签:
6条回答
  • 2020-12-05 17:40

    Here's an improvement on @XGamerX's answer.

    <%= link_to '#', [comment.post, { anchor: dom_id(comment) }] %>
    

    Or

    <%= link_to '#', post_path(comment.post, anchor: dom_id(comment)) %>
    
    0 讨论(0)
  • 2020-12-05 17:51

    Try this:

    <%= link_to '#', post_path(comment.post), :anchor => "comment_#{comment.id}" %>
    
    0 讨论(0)
  • 2020-12-05 17:54

    this is best way:

    <%= link_to '#', post_path(comment.post, anchor: dom_id(comment.id)) %>
    
    0 讨论(0)
  • 2020-12-05 17:58

    Actually, anchor is an option for the path, not for the link_to

    <%= link_to '#', post_path(comment.post, :anchor => "comment_#{comment.id}") %>
    

    http://api.rubyonrails.org/classes/ActionView/Helpers/UrlHelper.html#M001565

    link_to "Comment wall", profile_path(@profile, :anchor => "wall")
           # => <a href="/profiles/1#wall">Comment wall</a>
    
    0 讨论(0)
  • 2020-12-05 17:58

    These links will scroll down to position where you have code like:

    <a name="comment_1"></a>
    

    I don't know if there are helpers that will do it for you, but it is very simple and you can write your own.

    0 讨论(0)
  • 2020-12-05 18:02

    It looks like you want to use the link_to code that you have in your question. Then in your list of comments you have to make sure that you have an anchor tag named the same thing in the link.

    So this:

     <%= link_to 'Your comment', post_path(@comment.post) + "#comment_#{@comment.id.to_s}" %>
    

    will generate something like this

     <a href="localhost:3000/posts/2#1comment_234">Your comment</a>
    
     /* html code */     
    
     <a name="comment_1234">This is a comment</a>
    

    You have to manually tack on the #comment_ otherwise the link_to method thinks that the :anchor attribute that you are passing it is for that tag.

    0 讨论(0)
提交回复
热议问题