随笔-167  评论-65  文章-0  trackbacks-0

环境: ruby 1.8.7 + rails 2.1.0 

预览效果:

clip_image001

步骤:

1,在helpers 添加 继承 类

class RemoteLinkRenderer < WillPaginate::LinkRenderer

def prepare(collection, options, template)

@remote = options.delete(:remote) || {}

super

end

protected

def page_link(page, text, attributes = {})

@template.link_to_remote(text, {:url => url_for(page), :method => :get}.merge(@remote))

end

end

2,在config下的enviroment.rb 最后添加

WillPaginate::ViewHelpers.pagination_options[:class] = 'digg_pagination'

WillPaginate::ViewHelpers.pagination_options[:previous_label] = '上一页'

WillPaginate::ViewHelpers.pagination_options[:next_label] = '下一页'

WillPaginate::ViewHelpers.pagination_options[:renderer] = 'RemoteLinkRenderer'

3 建立css 样式表

.digg_pagination { /* 样式一 */

background: white;

/* self-clearing method: */ }

.digg_pagination a, .digg_pagination span {

padding: .2em .5em;

display: block;

float: left;

margin-right: 1px; }

.digg_pagination span.disabled {

color: #999;

border: 1px solid #DDD; }

.digg_pagination span.current {

font-weight: bold;

background: #2E6AB1;

color: white;

border: 1px solid #2E6AB1; }

.digg_pagination a {

text-decoration: none;

color: #105CB6;

border: 1px solid #9AAFE5; }

.digg_pagination a:hover, .digg_pagination a:focus {

color: #003;

border-color: #003; }

.digg_pagination .page_info {

background: #2E6AB1;

color: white;

padding: .4em .6em;

width: 22em;

margin-bottom: .3em;

text-align: center; }

.digg_pagination .page_info b {

color: #003;

background: #6aa6ed;

padding: .1em .25em; }

.digg_pagination:after {

content: ".";

display: block;

height: 0;

clear: both;

visibility: hidden; }

* html .digg_pagination {

height: 1%; }

*:first-child+html .digg_pagination {

overflow: hidden; }

.apple_pagination {

background: #F1F1F1;

border: 1px solid #E5E5E5;

text-align: center;

padding: 1em; }

.apple_pagination a, .apple_pagination span {

padding: .2em .3em; }

.apple_pagination span.disabled {

color: #AAA; }

.apple_pagination span.current {

font-weight: bold;

background: transparent url(apple-circle.gif) no-repeat 50% 50%; }

.apple_pagination a {

text-decoration: none;

color: black; }

.apple_pagination a:hover, .apple_pagination a:focus {

text-decoration: underline; }

4,view中使用;

共找到<%= @messages.total_entries %>条记录,共<%= @messages.total_pages %>页.

<%= will_paginate @messages ,:remote => {:update => 'messages'} %>


这样的做法, 是放在了enviroment.rb中,即是default的, 那么 我想单独设置怎么办呢。。。在view 中如下写法即可以:

<%= will_paginate @messages , :renderer => 'RemoteLinkRenderer' , :class => 'apple_pagination' ,:previous_label => '<<上一页', :next_label => '下一页>>' %>

 Link:

http://woork.blogspot.com/2008/03/perfect-pagination-style-using-css.html

http://weblog.redlinesoftware.com/2008/1/30/willpaginate-and-remote-links

http://thewebfellas.com/blog/2008/8/3/roll-your-own-pagination-links-with-will_paginate



write by feng
posted on 2009-03-25 09:37 fl1429 阅读(1771) 评论(0)  编辑  收藏 所属分类: Rails

只有注册用户登录后才能发表评论。


网站导航:
 
已访问数:
free counters