zoukankan      html  css  js  c++  java
  • 我的开源框架之面板控件

    需求:

    (1)可伸缩、扩大、缩小

    (2)可自定义工具栏(依赖工具栏控件),工具栏可定义位置

    (3)可加装远程数据

    实现图例

    客户代码

            function addMoreTools() {
                var toolbar = panel.panel("getToolbar");
                toolbar.toolbar('addButtons', [
                   {
                       id: 'btn_5',
                       text: '按钮5',
                       iconCls: 'icon-edit',
                       handler: function () {
                           alert("我的处理5");
                       }
                   }, {
                       id: 'btn_6',
                       text: '按钮6',
                       iconCls: 'icon-add',
                       handler: function () {
                           alert("我的处理6");
                       }
                   }
                ]);
            }
            function delTools() {
                var toolbar = panel.panel("getToolbar");
                toolbar.toolbar('delButtons', ['btn_1']);
            }
            function disableTools() {
                var toolbar = panel.panel("getToolbar");
                toolbar.toolbar('disableButtons', ['btn_2']);
            }
            function enableTools() {
                var toolbar = panel.panel("getToolbar");
                toolbar.toolbar('enableButtons', ['btn_2']);
            }
            var panel;
            $(function () {
                panel = $("#panelContainer").panel({
                    //toolbarPostion:'left',
                    title: '我的标题',
                    iconCls: 'icon-save',
                    collapseable: true, //可收缩
                    remoteRequest: {
                        url: 'content.html',
                        load: function () { },
                        loaded: function (result) { }
                    }
                });
            });
            function addTools() {
                panel.panel("addTools", {
                    btnList: [
                    {
                        id: 'btn_1',
                        text: '按钮1',
                        iconCls: 'icon-edit',
                        handler: function () {
                            alert("我的处理1");
                        }
                    }, {
                        id: 'btn_2',
                        text: '按钮2',
                        iconCls: 'icon-add',
                        handler: function () {
                            alert("我的处理2");
                        }
                    }
                    ]
                });
            }
            function reload(flag) {
                if (flag == 1) {
                    panel.panel("remoteLoad", {
                        url: 'testServer/jsonQuestTest.ashx',
                        dataType: 'json',
                        load: function () { },
                        loaded: function (result) {
                            panel.panel("setContect", result);
                        }
                    });
                } else {
                    panel.panel("reload", {
                        dataType: 'html',
                        url: 'content.html',
                        load: function () { },
                        loaded: function (result) {
                        }
                    });
                }
            }

    组件代码

    /******************************************
    *作者:hjwen
    *电邮:hjwen88@126.com
    *版本:1.0
    *版权许可:中国通用开源许可协议V1.0
    *说明:面板定义
    ******************************************/
    (function ($) {    
        /******渲染目标*******/
        function renderHtml(target) {
            var opts = target.data('settings');
            target.addClass("panel-body");
           var csswidth =  target.css("width");
            var width = target.width();
            var height = target.height();
            target.attr('originalwidth', width);//先保留原来的宽度
            target.attr('originalheight', height);//先保留原来的宽度       
            if (width == 0) {
                if (opts.width != 'auto') {
                    width = opts.width;
                } else {
                    width = target.parent().width();
                }
            }
            if (height == 0) {
                if (opts.height != 'auto') {
                    height = opts.height;
                } else {
                    height = target.parent().height();
                }
            }
            var headerBorderStyle = "";
            if (opts.displayBorder) {
                headerBorderStyle = "border-left:none;border-top:none;border-right:none;";
                target.css("border","none");
            }
            if (opts.fillAuto) {
                width = 'auto';
            } else {
                width = width+'px';
            }
            var wrap = target.wrap("<div style="" + width + ";height:" + height + "px;" class="panel-wrap"></div>").css({  'auto' });
            var toolsClass,titleClass;
            if (opts.toolbarPostion === 'left') {
                titleClass = "panel-tilte panel-tilte-pos-right";
                toolsClass = "panel-tools panel-tools-pos-left ";
            } else {
                titleClass = "panel-tilte panel-tilte-pos-left";
                toolsClass = "panel-tools panel-tools-pos-right ";
            }
            var titleWrap = $("<div style="" + headerBorderStyle + "" class="panel-header"><div  class="" + titleClass + ""><h2 style="padding-right:6px"></h2></div><div  class="" + toolsClass + ""></div></div>");
            target.before(titleWrap);       
            //设置title
            titleWrap = target.prev();
            if (opts.title != null) {
                titleWrap.children(".panel-tilte").children("h2").html(opts.title);
            }
            if (opts.iconCls != null) {
                titleWrap.children(".panel-tilte").children("h2").addClass(opts.iconCls).css("padding-left", "18px");
            }
            //设置自带工具
            var toolWrap = titleWrap.children(".panel-tools");
            if (opts.expandable) {//可上下展开
                $("<div class="panel-tool-btn panel-tool-expand"></div>").prependTo(toolWrap).bind({
                    click: _expandToggle,
                    mouseover: function () {
                        $(this).addClass("panel-tool-btn-hover");
                    },
                    mouseout: function () {
                        $(this).removeClass("panel-tool-btn-hover");
                    }
                });
            }
            if (opts.maximizable) {//可大小控制
                var tmpObj = $("<div class="panel-tool-btn"></div>").prependTo(toolWrap).bind({
                    click: _maxminToggle,
                    mouseover: function () {
                        $(this).addClass("panel-tool-btn-hover");
                    },
                    mouseout: function () {
                        $(this).removeClass("panel-tool-btn-hover");
                    }
                });
                if (opts.maximized) {
                    tmpObj.addClass("panel-tool-min");
                } else {
                    tmpObj.addClass("panel-tool-max");
                }
            }
            if (opts.closeable) {//可关闭
                $("<div class="panel-tool-btn panel-tool-closeable"></div>").prependTo(toolWrap).bind({
                    click: _close ,
                    mouseover: function () {
                        $(this).addClass("panel-tool-btn-hover");
                    },
                    mouseout: function () {
                        $(this).removeClass("panel-tool-btn-hover");
                    }
                });
            }
            if (opts.collapseable) {//可左右收缩
                var iocClass;
                if (opts.collapsePostion === 'left')
                    iocClass = "panel-tool-btn-left";
                else
                    iocClass = "panel-tool-btn-right";
                $("<div class="panel-tool-btn " + iocClass + ""></div>").prependTo(toolWrap).bind({
                    click: _collapsedToggle,
                    mouseover: function () {
                        $(this).addClass("panel-tool-btn-hover");
                    },
                    mouseout: function () {
                        $(this).removeClass("panel-tool-btn-hover");
                    }
                });
            }
            target.css("height", (height - titleWrap.innerHeight()-3) + "px");
            /*************UI交互定义**************/
            function _close() {
                close(target);
            };
            function _maxminToggle() {
                if ($(this).hasClass('panel-tool-min')) {
                    min(target);
                } else {
                    max(target);
                }
            };
            function _expandToggle() {
                if ($(this).hasClass('panel-tool-expand')) {
                    disexpand(target);
                } else {
                    expand(target);
                }
            };
            function _collapsedToggle() {
                var iocClass;
                if (opts.collapsePostion === 'left')
                    iocClass = "panel-tool-btn-right";
                else
                    iocClass = "panel-tool-btn-left";
    
                if ($(this).hasClass(iocClass)) {
                    discollapsed(target);
                } else {
                    collapsed(target);
                }
            };
            remoteRequest(target);
        };
        /************私有方法********************/
        /****
        *远程加载数据
        ****/
        function remoteRequest(target) {
            var opts = target.data('settings');
            if (opts.remoteRequest == null)
                return;
            if (typeof opts.remoteRequest === 'object' && typeof opts.remoteRequest.url != 'undefined') {           
                var dataType = typeof opts.remoteRequest.dataType === 'undefined' ? 'html' : opts.remoteRequest.dataType;               
                if (dataType != 'json') {
                    var settings = { url: opts.remoteRequest.url };
                    if (typeof opts.remoteRequest.load == 'function')
                        settings.load = opts.remoteRequest.load;
                    if (typeof opts.remoteRequest.loaded == 'function')
                        settings.loaded = opts.remoteRequest.loaded;
                    $.myui.objectLoadContect({
                        target: target,
                        settings: settings
                    });
                } else {
                    var ajaxopt = {
                        url: opts.remoteRequest.url,
                        loadingContainer: target
                    };
                    if (typeof opts.remoteRequest.loaded === 'function') {
                        ajaxopt.okdeal = opts.remoteRequest.loaded;
                    }
                    if (typeof opts.remoteRequest.load == 'function')
                        opts.remoteRequest.load();
                    $.myui.ajaxRequest(ajaxopt);
                }
            }
        };
        /***
        *重新设置面板内容高度
        ****/
        function resizeBobyHeight(target) {
            var titleWrap = target.prev();
            var height = target.parent().innerHeight();
            target.css("height", (height - titleWrap.innerHeight() - 3) + "px");
        };
        //展开
        function discollapsed(target) {      
            var opts = target.data('settings');       
            if (typeof opts.onCollapse === 'function') {
                opts.onCollapse(target,1);
            }
            var wrap = target.parent();
            var header = target.prev();
            header.addClass("panel-header");
            if (opts.collapsePostion === 'left'){
                header.find(".panel-tool-btn-right").removeClass("panel-tool-btn-right").addClass("panel-tool-btn-left");
            } else{
                header.find(".panel-tool-btn-left").removeClass("panel-tool-btn-left").addClass("panel-tool-btn-right");
            }
                
            if (opts.fillAuto) {
                header.css("border-bottom", "1px solid #99BBE8");
                wrap.width('auto');
            } else {
                header.css("border", "1px solid #99BBE8");
                wrap.width(target.attr('originalwidth'));
            }
            header.children(".panel-tilte").show();
            header.children(".panel-tools").children("div").show();
            wrap.css("background", "none");
            wrap.css("border", "none");
            wrap.height(target.attr('originalheight'));
            target.show();
            if (typeof opts.onCollapsed === 'function') {
                opts.onCollapsed(target, 1);
            }
        };
        //收缩
        function collapsed(target) {
            var opts = target.data('settings');       
            if (typeof opts.onCollapse === 'function') {
                opts.onCollapse(target, 0);
            }
            var wrap = target.parent();
            wrap.width(20);
            wrap.css("background-color", "#C1D1E5");
            var header = target.prev();
            header.removeClass("panel-header");  
            header.css({"border":"none","position":"relative","height":"28px"});
            header.children(".panel-tilte").hide();
           
            if (opts.collapsePostion === 'left') {
                header.children(".panel-tools").children("div:not(.panel-tool-btn-left)").hide();
                header.find(".panel-tool-btn-left").removeClass("panel-tool-btn-left").addClass("panel-tool-btn-right");
            } else {
                header.children(".panel-tools").children("div:not(.panel-tool-btn-right)").hide();
                header.find(".panel-tool-btn-right").removeClass("panel-tool-btn-right").addClass("panel-tool-btn-left");
            }
                   
            if (!opts.displayBorder) {
                wrap.height(wrap.height()-2);
                wrap.css("border", "1px solid #99BBE8");
            }
            target.hide();
            if (typeof opts.onCollapsed === 'function') {
                opts.onCollapsed(target, 0);
            }
        };
        /***
        *关闭
        ****/
        function close(target) {
            var opts = target.data('settings');
            if (typeof opts.onClose === 'function') {
                opts.onClose(target);
            }
            var wrap = target.parent();
            target.removeData('settings');
            wrap.remove();
            if (typeof opts.onClosed === 'function') {
                opts.onClosed();
            }
        };
        /***
         *最大化
         ****/
        function max(target) {
            var wrap = target.parent();
            var parent = wrap.parent();
            var newWidth = parent.width()-2;//border宽度占用了两个像数
            var newHeight = parent.height();      
            var opts = target.data('settings');
            wrap.css({  newWidth + "px", height: newHeight + "px" });
            target.prev().find(".panel-tool-max").removeClass("panel-tool-max").addClass("panel-tool-min");
            resizeBobyHeight(target);
        };
        /***
        *还原
        ****/
        function min(target) {
            var wrap = target.parent();
            var opts = target.data('settings');
            wrap.css({  target.attr('originalwidth') + "px", height: target.attr('originalheight') + "px" });
            target.prev().find(".panel-tool-min").removeClass("panel-tool-min").addClass("panel-tool-max");
            resizeBobyHeight(target);
        };
        /***
        *向下展开
        ****/
        function expand(target) {
            var opts = target.data('settings');
            var wrap = target.parent();
            wrap.height(opts.srcWrapHeight + "px");
            if (typeof opts.onExpand === 'function') {
                opts.onExpand(target);
            }
            target.show().prev().find(".panel-tool-disexpand").removeClass("panel-tool-disexpand").addClass("panel-tool-expand");
            if (typeof opts.onExpanded === 'function') {
                opts.onExpanded(target);
            }
        };
        /***
        *向上收起
        ****/
        function disexpand(target) {
            var wrap = target.parent();
            var srcWrapHeight = wrap.height();
            var opts = target.data('settings');
            opts.srcWrapHeight = srcWrapHeight;
            wrap.height(target.prev().height() + "px");        
            if (typeof opts.onExpand === 'function') {
                opts.onExpand(target);
            }
            target.hide().prev().find(".panel-tool-expand").removeClass("panel-tool-expand").addClass("panel-tool-disexpand");
            if (typeof opts.onExpanded === 'function') {
                opts.onExpanded(target);
            }
        };
        /**********私有方法结束*******************/
        var methods = {
            init: function (options) {
                return this.each(function () {               
                    var $this = $(this);
                    var settings = $this.data('settings');
                    if (typeof (settings) == 'undefined') {
                        settings = $.extend({}, $.fn.panel.defaults, options);
                        $this.data('settings', settings);
                    } else {
                        settings = $.extend({}, settings, options);
                    }
                    //创建ui布局
                    renderHtml($this);
                });
            },
            destroy: function () {
                return $(this).each(function () {
                    var $this = $(this);
                    close($this);
                });
            },
            /****
            * 添加工具参数说明:
            * options={
                        btnStyle:'plain',
                        btnList:[{  text:'按钮名称',
                       iconCls:'图标类名称'
                        handler:function(){.........}处理事件
                    },..........]}
            *****/
            addTools: function (options) {
                return $(this).each(function () {
                    var $this = $(this);
                    if ($this.data('settings').toolbar == null) {
                        var toolWrap = $this.prev().children(".panel-tilte");
                        var tool_cotainer = $("<div class="tool-container"></div>").appendTo(toolWrap);
                        if (typeof options.btnStyle == 'undefined')
                            options.btnStyle = 'plain';
                        $this.data('settings').toolbar = tool_cotainer.toolbar(options);
                    } else {
                        $this.data('settings').toolbar.toolbar('addButtons', options.btnList);
                    }
                });
            },
            /****
            * 获取工具栏对象
            ****/
            getToolbar: function () {
                var $this = $(this);
                var toolbar = null;
                if ($this.data('settings').toolbar == null) {
                    var toolWrap = $this.prev().children(".panel-tilte");
                    var tool_cotainer = $("<div class="tool-container"></div>").appendTo(toolWrap);
                    toolbar = tool_cotainer.toolbar({ btnList: [] });
                } else {
                    toolbar = $this.data('settings').toolbar;
                }
                return toolbar;
            },
            /****
              *加载远程内容
              * options={  url:'远程地址',
                          dataType:'html/json' //数据类型,是html还是json
                          load:function(){.........} , //加载前处理事件                     
                          loaded:function(result){.........}  //加载后处理事件       
                      }
              *****/
            remoteLoad: function (options) {
                return $(this).each(function () {
                    var $this = $(this);
                    if (typeof options == 'undefined' || typeof options.url == 'undefined' || options.url == '') {
                        alert("url参数是必须的!");
                    } else {
                        var newOpt = $.extend({}, $this.data('settings').remoteRequest, options);
                        $this.data('settings').remoteRequest = newOpt;
                        remoteRequest($this);
                    }
                });
            },
            /****
            *重新加载远程内容
            * options={   url:'远程地址',
                        dataType:'html/json' //数据类型,是html还是json
                        load:function(){.........} , //加载前处理事件                   
                        loaded:function(result){.........}  //加载后处理事件       
                    }
            *****/
            reload: function (options) {
                return $(this).each(function () {
                    var $this = $(this);
                    if (typeof options == 'undefined' && $this.data('settings').remoteRequest == null) {
                        alert("找不到远程请求参数!");
                    } else {
                        var newOpt = $.extend({}, $this.data('settings').remoteRequest, options);
                        $this.data('settings').remoteRequest = newOpt;
                        remoteRequest($this);
                    }
                });
            },
            /****
            *设置内容
            *****/
            setContect: function (content) {
                return $(this).each(function () {
                    var $this = $(this);
                    $this.html(content);
                });
            }
        }
        $.fn.panel = function () {
            var method = arguments[0];
            if (methods[method]) {
                method = methods[method];
                arguments = Array.prototype.slice.call(arguments, 1);
            } else if (typeof (method) == 'object' || !method) {
                if ($.myui.isDebug) {
                    $.myui.log("jQuery.panel init.....");
                }
                method = methods.init;
            } else {
                $.error('Method ' + method + ' does not exist on jQuery.panel');
                return this;
            }
            return method.apply(this, arguments);
        };
        /***默认值*********************************************
            remoteRequest={  url:'远程地址',
            *               dataType:'html/json' //数据类型,是html还是json
            *               load:function(){.........} , //加载前处理事件
            *               loaded:function(result){.........}  //加载后处理事件       
            *        }
        *******************************************************/
        $.fn.panel.defaults = {
            title: null,//标题
            iconCls: null,//图标cls,对应icon.css里的class 
            toolbar: null,//工具栏对象
            toolbarPostion: 'right',
            collapsePostion: 'left',//收缩的方向,用于布局指定收缩图标,默认是往左边收缩
             'auto',
            height: 'auto',
            expandable:true,//可展开
            maximizable: true,//可最大化 
            closeable: true,//可关闭
            expanded:true,//是否展开
            collapseable: false,//是否收缩      
            maximized: false,//是否最大化
            closed: false,//是否关闭       
            remoteRequest: null,//远程加载页面的参数对象
            loadingMessage: '正在加载...',
            onLoad: function (self) {},//加载前
            onLoaded: function (self) { },//加载后
            onCollapse: function (self, flag) { },//收缩前 flag=0 收缩,1展开
            onCollapsed: function (self, flag) { },//收缩后 flag=0 收缩,1展开
            onClose: function (self) { },//关闭前
            onClosed: function () { },//关闭后
            onExpand: function (self, flag) { },//展开前 flag=0 收缩,1展开
            onExpanded: function (self, flag) { },//展开后 flag=0 收缩,1展开
            displayBorder: false, //是否显示外边框 用于面板被嵌套到layout时,去掉面板的外边框
            fillAuto:false  //自适应外部容器
        };
    })(jQuery);
  • 相关阅读:
    <记录> axios 模拟表单提交数据
    PHP 设计模式(一)
    CSS3中translate、transform和translation的区别和联系
    微信小程序 支付功能 服务器端(TP5.1)实现
    微信小程序 用户登录 服务器端(TP5.1)实现
    <记录> curl 封装函数
    <记录>TP5 关联模型使用(嵌套关联、动态排序以及隐藏字段)
    PHP/TP5 接口设计中异常处理
    TP5 自定义验证器
    高并发和大流量解决方案--数据库缓存
  • 原文地址:https://www.cnblogs.com/hjwen/p/3791509.html
Copyright © 2011-2022 走看看