zoukankan      html  css  js  c++  java
  • 简单分页实现

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="utf-8">
        <title>用react写表单验证</title>
        <script src="http://cdn.amazeui.org/react/0.14.3/react.min.js"></script>
        <script src="http://cdn.amazeui.org/react/0.14.3/react-dom.min.js"></script>
        <script src="//cdn.bootcss.com/babel-core/5.8.33/browser.min.js"></script>
        <style>
        .fl{float: left;}
        .fr{float: right;}
        .ui-pagnation {display: block; margin-top: 50px; color: #535353; line-height: 29px; text-align: center }
        .ui-pagnation a {float: left; min- 30px; height: 30px; padding: 0 7px; vertical-align: middle; text-decoration: none; cursor: pointer;}
        .ui-pagnation .next,.ui-pagnation .prev {margin: 0 9px; background-color: #f3f4f8; border: 1px solid #00a0e9 }
        .ui-pagnation .next:before,.ui-pagnation .prev:before {content: '<'; color: #00a0e9; font-size: 14px }
        .ui-pagnation .next:hover,.ui-pagnation .prev:hover {border-color: #50c8ff }
        .ui-pagnation .next:hover:before,.ui-pagnation .prev:hover:before {color: #50c8ff }
        .ui-pagnation .disable.next,.ui-pagnation .prev.disable {background-color: #f3f4f8; border-color: #a0a0a0; cursor: no-drop;}
        .ui-pagnation .disable.next:before,.ui-pagnation .prev.disable:before {color: #a0a0a0 }
        .ui-pagnation .next:before {content: '>'}
        .ui-pagnation .num {margin-left: -1px; padding: 0 7px; border: 1px solid #e5e5e5; color: #707070 }
        .ui-pagnation .num.current,.ui-pagnation .num:hover {background-color: #a7bbcb; border-color: #a7bbcb; color: #fff }
        .ui-pagnation .ellipsis { 42px; height: 30px; color: #707070; line-height: 30px }
        .ui-pagnation input { 44px; height: 24px; border: 1px solid #eee; text-align: center }
        .ui-pagnation .page-go {min- 60px; margin-left: 10px; margin-right: 10px; background-color: #a7bbcb; border: 1px solid #879cac; color: #fff }
        .ui-pagnation .page-go:hover {background-color: #87a2b8; border-color: #698397 }
        </style>
    </head>
    <body>
    <div id="demo"></div>
    <script type="text/babel">
    
    var Page = React.createClass({
        getInitialState: function() {
            return {current: 1, value : ''};
        },
        handClick : function(e){
            let sel = this;
            return function(){
                sel.setState({current : e});
            }
        },
        handChange : function(e){
            this.setState({value : e.target.value})
        },
        goNext : function(){
            let cur = this.state.current;
            if(cur < this.props.total){
                this.setState({current : cur + 1});
            }
        },
        goPrev : function(){
            let cur = this.state.current;
            if(cur > 1){
                this.setState({current : cur - 1});
            }
        },
        goPage : function(){
            var val = this.state.value;
            if(!/^[1-9]d*$/.test(val)){
                alert('页码只能输入大于1的正整数');
            }else if(parseInt(val) > parseInt(this.props.total)){
                alert('没有这么多页');
            }else{
                this.setState({current : val});
            }
        },
        render : function(){
            let self = this;
            let total = this.props.total;
            let cur = this.state.current;
            let items = [];
            let begin;
            let len;
            if(total > 5){
                len = 5;
                if(cur >= (total-2)){
                    begin = total - 4;
                }else if(cur <= 3){
                    begin = 1;
                }else{
                    begin = cur - 2;
                }
            }else{
                len = total;
                begin = 1;
            }
            for(let i = 0; i < len; i ++){
                let cur = this.state.current;
                let showI = begin + i;
                if(cur == showI){
                    items.push({num : showI, cur : true});
                }else{
                    items.push({num : showI, cur : false});
                }
                
            }
            return  <div className="ui-pagnation">
                        <a className={this.state.current == 1? 'prev disable' : 'prev'} onClick={this.goPrev}></a>
                        <span className="pagnation-cols">
                            {
                                items.map(function(item){
                                    return <a onClick={self.handClick(item.num)} className={item.cur? 'num current' : 'num'}>{item.num}</a>
                                })
                            }
                        </span>
                        <a className={this.state.current == this.props.total? 'next disable' : 'next'} onClick={this.goNext}></a>
                        <div className="fl"><span className="num-total">{total}</span>
                            页,到第
                            <input type="text" value={self.state.value} onChange={this.handChange} />
    </div>
                        <a onClick={this.goPage} className="page-go">确定</a>
                    </div>
        }
    });
    
    ReactDOM.render(
        <div>
            <Page total="20" />
        </div>,
        document.getElementById('demo')
    );
    </script>
    </body>
    </html>
  • 相关阅读:
    moss jscript
    CSS两端对准
    简单的日期格式验证
    .NET中使用Exchange 2007 Webservice来读取邮件
    张二狗
    spcontext
    Infopath表单用改控件值提交或作别的更改时一定要在控件属性浏览器表单的回发设置为始终.
    使用 Web 服务
    SharePoint 2010中开发模式的改进 COM 客户端对象模型
    Retrieve data from Separate Oracle System
  • 原文地址:https://www.cnblogs.com/echo-ling/p/7708515.html
Copyright © 2011-2022 走看看