- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
假设下面的“books/book”部分是从多个位置调用的(例如:author#show View 、categogories#show View 、categories#index View )并且我只希望从 author#show 调用 votes 部分看法。也就是说,我希望从书籍部分 (@upvoted_books) 返回的书籍集合都呈现“投票/投票”部分,以便作者能够从他们的 author#show View 中对一本书进行投票。以下代码或其变体是否合理?
<%= render partial: "books/book", collection: @upvoted_books do |upvoted| %>
<%= render partial: "votes/vote", locals: {category: book.category, book: upvoted } %>
<% end %>
p.s:我在这里尝试了这个特定的代码,但它在我的项目中不起作用,但我只是想知道是否有类似的东西可以工作,但它也没有抛出任何明显的错误。也许我只是把语法搞混了。我也知道解决相同问题的其他几种方法,但我一直在寻找更优雅的方法。感谢期待您的创造性回应。
更新:
感谢@Deep,提供非常有见地的解决方案。我之前为解决问题所做的是从“books/book”部分调用下面的行:
<% if defined?(@upvoted_books) && @upvoted_books.include?(book) %>
<%= render partial: "votes/vote", locals: {category: book.category, book: upvoted } %>
<% end %>
这行得通,但我不确定它是否有明显的代码异味,或者它的语法是否笨拙。你怎么看?
最后更新:
@Deep 这些是您要求的 View :这是我的类别#show View :
`<h1>Topics#show</h1>
<p><%= @category.title %></p>
<%= render partial: "books/form", locals: {topic: @category, book: Book.new} %>
<%= link_to "edit category", edit_author_category_path(@category.author, @category) %>
<p> Books you have Authored </p>
<%= render partial: "books/book", collection: @category.books %>`
And this is my books/_book.html.erb partial now
`<% if defined?(upvoted_book) && current_author.books.include?(upvoted_book) %>
<h5>Created by <%= upvoted_book.category.author.name || upvoted_book.category.author.email %> on <%= upvoted_book.created_at %></h>
<br>
<%= link_to upvoted_book.title, category_book_path(upvoted_book.category, upvoted_book) %>
<% if policy(Vote.new).create? %>
<%= render partial: "votes/vote", locals: {category: upvoted_book.category, book: upvoted_book} %>
<br>
<% end %>
<% else %>
<h5>Created by <%= book.category.author.name || book.category.author.email %> on <%= book.created_at %></h>
<br>
<%= link_to book.title, category_book_path(book.category, book) %>
<%= link_to "Remove book", category_book_path(book.category, book), method: :delete, data: { confirm: "Are you sure you want to delete this book?" } %>
<% end %>`
如您所见,我在部分中引用了局部变量 book 和 upvoted_book。这就是我从作者#show View 中调用部分内容的方式:`
<%= render partial: "categories/form", locals: {category: Category.new, author: @author} %>
<p> Categories and Books you have Writen: </p>
<%= render partial: "categories/category", collection: @categories %>
<p> Books from all authors that you have Upvoted: </p>
<%= render partial: "books/book", collection: @upvoted_books, as: :upvoted_book %>
<br> `
Thanks for you wonderful insight again.
最佳答案
由于您需要在每本书上只在一个 View 中呈现部分投票,所以您可以做的是:
<%= render partial: "books/book", collection: @upvoted_books, locals: { vote: true } %>
现在在你的部分书中写下:
if vote
<%= render partial: "votes/vote", locals: {category: book.category, book: upvoted } %>
end
并确保在渲染 book
的其余地方部分通过 locals: { vote: false }
否则会抛出错误。或者你可以在部分中做的是:
vote ||= false
或者您可以使用 if defined?(vote)
而不是使用 if vote
,这样就没有从其他页面传递它的负担。
另外我怀疑你有一些错误的本地人,不确定他们是否正确。但是使用它,您可以在单个 View 上调用部分 vote
。
希望这对您有所帮助。
关于ruby-on-rails - rails 上的 ruby : Is it possible to nest partial calls/rendering like so:,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31661157/
我需要在每个渲染帧完成后拍摄屏幕截图,但我发现某些屏幕截图是重复的,所以我想知道是否可以在渲染完成之前保存屏幕截图。因此... renderer.render() 会阻塞直到完成渲染吗? 如果没有,有
web.py 骨架代码中的“render._keywords['globals']['render'] = render”是什么意思? http://webpy.org/skeleton/0.3 最佳
所以在我的 Nuxt universal-mode 应用程序中,我有时会出现错误: vue.runtime.esm.js:620 [Vue warn]: The client-side rendere
我想创建一个 portal-like effect使用 Bevy . Unity 似乎有一个 render texture实现这一目标。 有没有办法在 Bevy 中做同样的事情?如果没有, futur
我有一个看起来像这样的组件(非常简化的版本): const component = (props: PropTypes) => { const [allResultsVisible, setA
编辑:我调整了代码,但问题仍然存在。见下文 我有这个 p:selectOneRadio : 而这个 p:radioButton : 和 AData包含其
为了渲染部分我可以使用 render 'partial_name' 或 render partial: 'partial_name' 我开始知道 render 是 render partial 的简写
我注意到文章中的一些地方使用了 React.render() 和一些地方 ReactDOM.render()。这两者有什么具体区别吗? 最佳答案 这是 0.14 中引入的最新更改。他们将 React
我的代码是这样的: function render() { renderer.render( scene, camera ); renderer.clear(); } 我想知道为什么它
我目前正在实现 useSWR 以便从我的 express 和 mongo-db 后端获取数据。我能够从数据库中成功获取数据没问题。以下是我用来实现此目的的代码: ```//SWR method for
我只有在按照 React native - "this.setState is not a function" trying to animate background color? 的建议合并了 u
所以我有一个大的纹理,被分成 64x64 block 。 我使用将其加载到 LibGDX texture = new Texture("texturemap.png"); regions = Text
我对放置 @Scripts.Render 和 @Styles.Render 的位置感到很困惑。理想情况下,我会将它们全部放在 head 部分中,但出乎意料的是,例如 @Scripts.Render("
我正在尝试使用 jamon 来收集使用 Tapestry 的网站的统计信息(呈现网页的时间)。 我怎样才能拥有 服务器收到请求时执行的方法,即渲染开始时? 响应全部发送完毕,即渲染结束时执行的方法 ?
在我的 React 应用程序中,我想要渲染一个 prop 值,但直到渲染完成后更新 props 后它才存在。 this.props.users 是一个对象,因此我使用 Object.keys() 转换
我正在使用 React 的钩子(Hook),我希望有一个从数据库中检索到的值作为初始值。但是,我收到以下错误: Invariant Violation: Invariant Violation: Re
我正在尝试按照以下代码将多个场景包含到单个 webgl 渲染器中: renderer.render(scene1, camera); renderer.render(scene2, camera);
我在我的 xhtml 页面中使用此代码,当我运行应用程序时,元描述仍在呈现。我想根据某些条件使用元描述标签。主布局: ..........
我正在使用react-native-render-html来渲染html。renderers方法允许我提供自定义函数来呈现特定标签。不过,我想使用源代码中的原始内部 HTML 将子组件替换为我的自定义
我有一个网格,可以渲染可变高度的卡片。 为了获取卡片的高度,我将卡片渲染在 ReactHeight 中。 ( https://github.com/nkbt/react-height ),这让我可以在
我是一名优秀的程序员,十分优秀!