我环顾四周,但找不到关于我需要做些什么才能使以下内容成为可能的线索:
这个问题假设我所有模型控制器都正常工作,并且命名的 CSS 属性是在默认样式表中定义的。
我希望用户能够在登录时选择一些 CSS 属性来个性化他们自己的主题。基本属性是“body”和“page-wrapper”颜色。(前景)
我希望他们能够在用户的编辑页面中选择这些属性(从表单中?)。(已经创建)
关于如何使这项工作或在正确方向上取得良好领导的任何想法?
谢谢你的帮助。
我环顾四周,但找不到关于我需要做些什么才能使以下内容成为可能的线索:
这个问题假设我所有模型控制器都正常工作,并且命名的 CSS 属性是在默认样式表中定义的。
我希望用户能够在登录时选择一些 CSS 属性来个性化他们自己的主题。基本属性是“body”和“page-wrapper”颜色。(前景)
我希望他们能够在用户的编辑页面中选择这些属性(从表单中?)。(已经创建)
关于如何使这项工作或在正确方向上取得良好领导的任何想法?
谢谢你的帮助。
我认为最好的方法是通过 javascript,在头部生成一个带有所需样式的样式标签。Jquery 提供了一种简单的方法来做到这一点,您可以将样式存储在模型的列中。
像这样的东西:
class User
attr_accesible :styles
查看.erb
<script>
// Assume the @styles attr has something like "body { background-color: #567;}"
$('head').append($('<style>').html('<%= @user.styles %>'))
</script>
@styles 将是您模型中的另一列,因此您应该通过迁移添加它
rails g migration addstylestousers styles:string
在你的 form.erb
<%= f.label :styles %>
<%= f.text_field :styles %>
我认为只要您给他足够的提示,例如“body { background-color: red }
在此字段中添加使您的背景变红!”,用户将 css 样式放在这里就足够简单了。
关于序列化,请考虑this。
如果要嵌套样式,则脚本将是
//Lets say that the user stored on @bgcolor and @fgcolor only css color codes, like '#222' or 'blue'
var bgc = '<%= @user.style.bgcolor %>'
var fgc = '<%= @user.style.fgcolor %>'
var style = 'body { background-color: ' + bgc + '; foreground-color: ' + fgc + ' }'
$('head').append($('<style>').html(style))
请记住,关系应该User has_one :style
在这种情况下。但是,嵌套它会让自己陷入更多问题,我认为这根本不值得。