开发中遇到的疑难问题集锦(含代码)

浏览器中直接下载文件的设置方法
如果不需要pdf直接在浏览器中预览的效果,而是直接下载文件的话就把response.setHeader()方法里面的参数改成下面的,相当于加了一个attachment,以附件形式下载
response.setHeader("Content-Disposition","attachment;filename=" + new String(fileName.getBytes(), "iso8859-1"));

Get请求中文乱码的几种解决方式

1.将字符串转码:new String(“xxxxx”.getBytes("iso-8859-1"),"utf-8")
        这种转码方式有很大的弊端,因为它是使用指定的字符集将此String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中,然后通过使用指定的字符编码将生成的byte 数组解码,构造一个新的String字符串。这种情况就有可能遇到的情况是,不能将一个汉字全部解码完。这样,前边的都能正常显示,但是最后一个字可能是乱码。所以不建议使用这种方式。
        2.在传参前转码:接收参数后再转码回来。
        这种方式有两种:
        第一种:
        传参前:使用java.net.URLEncoder.encode("xxxx",“utf-8"),将中文转为16进制字符。
        接收参数后:使用java.net.URLDncoder.decode("xxxx",“utf-8")将16进制字符转为中文。
        这种方式需要注意的是,在使用encode转码后,会出现特殊字符,这时候,就需要将特殊字符替换为相应的16进制。因为特殊字符在url路径中做为参数传递时,也是乱码。


        第二种:
        传参前:encodeURI(“xxxx”) 。
        接收参数后:使用java.net.URLDncoder.decode("xxxx",“utf-8")将16进制字符转为中文。
        这种方式需要注意的是,在使用encodeURI转码后,会出现特殊字符,这时候,就需要将特殊字符也转码,所以使用两次encodeURI,即:encodeURI(encodeURI(“xxxx”))。
        这两种转码方式是很好用的,所以很建议大家使用。

        3. 修改tomcat配置文件:
        在Tomcat的安装目录下conf文件夹中的server.xml文件,将配置访问端口的地方加上URIEncoding=“utf8"即可。
        <Connector port="8080" maxThreads="150" minSpareThreads="25" maxSpareThreads="75" URIEncoding="GBK">
        不建议使用这种方式。

 

 

1.当layer.open打开的是iframe类型的页面时,如何操作该iframe中的Dom呢,如下:
layer.open({
    type: 2
    ,title: '选择角色'
    ,area: ['300px', '330px']
    ,shade: 0
    ,maxmin: true
    ,content: '${path}/user/roleTree'
    ,btn: ['确定', '关闭'] //只是为了演示
    ,yes: function(index, layero){
        //layer.getChildFrame(selector, index) - 获取iframe页的DOM
        var body = layer.getChildFrame('body', index);
        var iframeWin = window[layero.find('iframe')[0]['name']]; //得到iframe页的窗口对象,执行iframe页的方法:iframeWin.method();
        alert(body.html()) //得到iframe页的body内容
        body.find('input').val('Hi,我是从父页来的')
    }
    ,btn2: function(index){
        layer.close(index);
    }
});

 

 

 

2.load方法加载IScroll滑动模块,并实现用缓存来储存之前滑动的位置,当返回页面或第二次进入页面时直接跳转到之前的位置 function load () { var topy = sessionStorage.getItem("topy");  if(topy == null){ topy = 0;  } console.log(topy) var pullUp = $("#pullUp"),  pullUpLabel = $(".pullUpLabel"),  loadingStep = 0;//加载状态0默认,1显示加载状态,2执行加载数据,只有当为0时才能再次加载,这是防止过快拉动刷新    myScroll = new IScroll("#wrapper", { scrollbars: true,  mouseWheel: false,  interactiveScrollbars: true,  shrinkScrollbars: 'scale',  fadeScrollbars: true,  scrollY: true,  probeType: 2,  bindToWrapper:true,  click: true,  });   console.log(myScroll.y) //这里注意:Y一定要减一个数字,不然下次滑动会出错,之前就是在这里栽了跟头!  myScroll.scrollTo(0,topy-1);  //重新定位之后一定要刷新,不然后面滑动坐标会出错!  myScroll.refresh();  //刷新之后,Y坐标为最新  console.log(myScroll.y) myScroll.on("scroll",function(){ if(loadingStep == 0 ){ if(this.y < (this.maxScrollY - 10)){//上拉加载更多  pullUp.show();   //延迟加载特效  setTimeout(function () { count = Number(count)+start;  content(count);  },1000) loadingStep = 1;  pullUpAction();  } } });   function pullUpAction(){ var sy=myScroll.maxScrollY;  myScroll.refresh();   var newsy=myScroll.maxScrollY;  if(sy!=newsy){ myScroll.scrollTo(0,sy-30,1000);  } loadingStep = 0;  } myScroll.on("scrollEnd",function () { console.log("滚动完成") console.log(myScroll.y) console.log(myScroll.maxScrollY) sessionStorage.setItem("topy", myScroll.y);//保存滚动位置  }) document.addEventListener('touchmove', function (e) { e.preventDefault(); }, false); } 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值