总结前端常用控件和疑难杂症的解决方法

//点击展开的事件
function expandMoreStr(v) {
    var str="";
    if ($(v).find(‘i‘).hasClass(‘icon-sort-up‘)) {
        $(v).find(‘i‘).attr(‘class‘, ‘icon-sort-down‘);
        str = $(v).prev().attr(‘data-simple‘);
        $(v).prev().html(str);
    } else {
        $(v).find(‘i‘).attr(‘class‘, ‘icon-sort-up‘);
        $(v).prev().attr(‘class‘, ‘text-no-ellipsis‘);
        str = $(v).prev().attr(‘data-complete‘);
        $(v).prev().html(str);
    }
}

var commonHelper = {
        selectPickerHelp:{
            //selectPicker控件的使用
            init:function(docId,tip){
                //进入页面,首先初始化控件
                docId = "#"+docId;
                $(docId).selectpicker({noneSelectedText:tip});
            },
            building:function(param){
                //初始化控件的数据
                var docId = "#"+param.docId;
                if(null != param.size && "undefined" != param.size && "" != $.trim(param.size)){
                    $(docId).attr("data-size",param.size);
                }
                if(null != param.multiple && "undefined" != param.multiple && "" != $.trim(param.multiple)){
                    $(docId).attr("multiple",param.multiple);
                }
                if(null != param.width && "undefined" != param.width && "" != $.trim(param.width)){
                    $(docId).attr("data-width",param.width);
                }
                if(null != param.style && "undefined" != param.style && "" != $.trim(param.style)){
                    $(docId).attr("data-style",param.style);
                }
                var options = [];
                var data = param.dataParam.data;
                if(null != param.dataParam.expendData){
                    options.push(‘<option value="‘+param.dataParam.expendData["val"]+‘">‘+param.dataParam.expendData["name"]+‘</option>‘);
                }
                $.each(data,function(i,e){
                    options.push(‘<option value="‘+e[param.dataParam.val]+‘">‘+e[param.dataParam.name]+‘</option>‘);
                });
                $(docId).prepend(options.join(‘‘));
                if(null != param.defaultVal && "" != $.trim(param.defaultVal)&&"undefined"!=param.defaultVal){
                    if($(docId).attr("multiple") == "multiple"){
                        var selections = param.defaultVal.split(",");
                        $(docId).selectpicker(‘val‘,selections);
                    }else{
                        $(docId).selectpicker(‘val‘,param.defaultVal);
                    }
                }
                $(docId).selectpicker(‘refresh‘);
            },
            readValue:function(docId){
                var docId = "#"+docId;
                if($(docId).attr("multiple") == "multiple"){
                    return $(docId).val().join(",");
                }else{
                    return $(docId).val();
                }

            }
    },
    longStrHelper:{
            simplifyStr:function(data,max,style){
                //字符串串收起展示
                var div = [];
                var simpleData = data;
                if(null == data){
                    return "";
                }
                if(data.length>max){
                    simpleData=data.substring(0,max)+"... ...";
                }
                var defaultStyle = "table-layout:fixed;word-break:break-all;overflow:hidden;";
                if( null != style && "undefined" != style){
                    //过滤与默认样式重复的样式类型,保留默认样式start
                    style = style.replaceAll("\\s", "").replaceAll(" ", "");//去除所有空格
                    var styleArr = style.split(";");
                    var defaultKeys = ["table-layout","word-break","overflow"];
                    for(var i =0;i<defaultKeys.length;i++){
                         var dfk = defaultKeys[i];
                         if(style.indexOf(dfk)>-1){
                                alert(defaultStyle.indexOf(dfk));
                                styleArr = $.grep(styleArr,function(o,j){
                                  if(o.indexOf(dfk)<0){
                                      return o;
                                  }
                                });
                         }
                    }
                    //过滤与默认样式重复的样式类型,保留默认样式end
                    style = defaultStyle + styleArr.join(";");
                }else{
                    style = defaultStyle;
                }
                div.push(‘<span data-complete="‘+data+‘" data-simple="‘+simpleData+‘" style="‘+style+‘">‘+simpleData+‘</span>‘);
                if(simpleData!= data){
                    div.push(‘<a class="text-expand" href="javascript:void(0);" onclick="commonHelper.longStrHelper.expandStr(this);" style="float: right;"><i class="icon-sort-down"></i></a>‘);
                }
                return div.join(‘‘);
        },
        expandStr:function(v){
            //展开或收起长字符串
            var str="";
            if ($(v).find(‘i‘).hasClass(‘icon-sort-up‘)) {
                $(v).find(‘i‘).attr(‘class‘, ‘icon-sort-down‘);
                str = $(v).prev().attr(‘data-simple‘);
                $(v).prev().html(str);
            } else {
                $(v).find(‘i‘).attr(‘class‘, ‘icon-sort-up‘);
                $(v).prev().attr(‘class‘, ‘text-no-ellipsis‘);
                str = $(v).prev().attr(‘data-complete‘);
                $(v).prev().html(str);
            }
        }

    }

}
时间: 2024-10-13 00:45:50

总结前端常用控件和疑难杂症的解决方法的相关文章

QTP录制后弹出框一个或多个ActiveX控件无法显示的解决方法

制一段脚本代码,在专家视图窗口中编辑录制的脚本代码时,会碰到弹出一个对话窗口,提示为"当前安全设置禁止运行该页中的ActiveX 控件,因此,该页可能无法正常显示"类似的东西,而在人工操作时却没有这样的现象.(如图) 问题主要出在于QTP设置本身,之所以在编辑录制好的脚本时,QTP出现关于Active的对话提示窗口,问题在于QTP的设置,要消除该提示窗口.应对QTP作如下设置:toos–options–Active Screen–Advanced–点选Load ActiveX cont

C# DataGridView控件清空数据完美解决方法

C# DataGridView控件绑定数据后清空数据在清除DataGridview的数据时: 1.DataSource为NULL(DataGridView.DataSource= null;)这样会将DataGridView的列也删掉. 2.用DataGridview.Rows.Clear();  提示“不能清除此列表”!!!!! 以上都不是想要的结果.想要满足保持原有的列,就是重新绑定之前的DataTable,然后清除DataTable中的数据,如下: DataTable  dt  =  (D

jquery dialog open后,服务器端控件失效的快速解决方法

jquery dialog为我们提供了非常漂亮实用的对话框,比单调的alert.confirm.prompt好用很多. 在使用jquery与.net共同开发时,直接调用jquery dialog的open后,服务器端控件全部失效了,不能执行相应的后台代码.只是源于jquery默认把dialog添加到body中,而不是原来所在的服务器端的form中了 解决方法: 1.可以调用dialog的open前,$("#dialog").parent().appendTo("form:fi

Android开发:StaggeredGridView瀑布流控件运行异常崩溃解决方法

StaggeredGridView是github上一个开源的瀑布流图片库,本文将分享集成StaggeredGridView时碰到的异常以及解决方法,StaggeredGriedView开源地址为:https://github.com/maurycyw/StaggeredGridView. StaggeredGriedViewDemo运行报错异常为: java.lang.RuntimeException: Unable to start activity  ComponentInfo{com.ex

混合开发 webview 中file 控件 点击后无反应解决方法

最近在做个项目 ,需要 使用 file 控件上传 图片到服务器 ,在手机浏览器中 可以正常选择照片,但是放到 android 应用中的webview中,file 控件点击后就没有反应. 百度了一番后,找到以下解决方案 开头定义 private ValueCallback<Uri> mUploadMessage; final static int FILE_SELECTED = 4; 然后设置 mWebView.setWebChromeClient(new WebChromeClient() {

datetimepicker 时间控件 1899年问题以及解决方法

bootstrap-datetimepicker时间控件显示问题,显示1899年. 案例回顾: 第一次页面加载完点击时间控件,显示正常. 第二次点击的时候,发现显示为1899年 原因调查:结果发现日期格式化的代码出错了 这类问题可以去读一下bootstrap-datetimepicker的源代码,我们会发现它的日期format格式里面没有上述的这种日期格式,也就导致了日期控件选择时间后无法格式化导致内部异常出现了1899年这样的滑稽bug. 解决方案有2个, 一是直接修改format: 'yyy

转:C# DataGridView控件清空数据出错解决方法

C# DataGridView控件绑定数据后清空数据在清除DataGridview的数据时: 1.DataSource为NULL(DataGridView.DataSource= null;)这样会将DataGridView的列也删掉. 2.用DataGridview.Rows.Clear();  提示“不能清除此列表”!!!!! 以上都不是想要的结果.想要满足保持原有的列,就是重新绑定之前的DataTable,然后清除DataTable中的数据,如下: DataTable  dt  =  (D

关于ListView中item与子控件抢夺焦点的解决方法

1.在开发中,listview可以说是我们使用最频繁的控件之一了,但是关于listview的各种问题也是很多.当我们使用自定义布局的Listview的时候,如果在item的布局文件里面存在Button或者是CheckBox等控件以及其子类控件的时候,经常会碰到各种控件的点击事件冲突的情况,那么我们如何来处理Listview中这种控件之间焦点冲突的情况呢? 这里有三种解决方案 1.将ListView中的Item布局中的子控件focusable属性设置为false2.在getView方法中设置but

使用selenium时,使用从系统启动浏览器与通过自动化驱动方式启动浏览器控件ID不一样解决方法

最近遇到一个怪事,通过正常打开浏览器,按照正常的web登录然后点击进入系统流程,将各控件的ID识别成功,然后使用 python3+selenium写好脚本,高高兴兴的用脚本跑时老是提示找不到控件,然后就重新打开浏览器登录重新识别控件,发现识别出来的控件ID又跟之前的不一样,瞬间怀疑是不是自己的眼睛出现视觉疲劳了. 重新关闭所有浏览器重新登录,再次识别该有问题的控件,发现识别出来的控件又跟之前第一次识别出来的一样,但是用脚本跑时还是一如既往的提示找不到该 控件,于是乎就博客园,csdn,stack