前后台的一些事件记录(比较杂)

**记录一些鼠标事件(可能会补充也可能会新开博客)**

    • 解决文本框设置readonly后按退键后退页面问题(直接上代码片)
    • 前台自动换行
    • 下载时,不同浏览器乱码问题解决(主要针对360极速模式以及兼容模式)
    • excel导入时间格式处理

解决文本框设置readonly后按退键后退页面问题(直接上代码片)

//处理键盘事件 禁止后退键(Backspace)密码或单行、多行文本框除外
function forbidBackSpace(e) {
   var ev = e || window.event; //获取event对象 
   var obj = ev.target || ev.srcElement; //获取事件源 
   var t = obj.type || obj.getAttribute('type'); //获取事件源类型 
   //获取作为判断条件的事件类型 
   var vReadOnly = obj.readOnly;
   var vDisabled = obj.disabled;
   //处理undefined值情况 
   vReadOnly = (vReadOnly == undefined) ? false : vReadOnly;
   vDisabled = (vDisabled == undefined) ? true : vDisabled;
   //当敲Backspace键时,事件源类型为密码或单行、多行文本的, 
   //并且readOnly属性为true或disabled属性为true的,则退格键失效 
   var flag1 = ev.keyCode == 8 && (t == "password" || t == "text" || t == "textarea") && (vReadOnly == true || vDisabled == true);
   //当敲Backspace键时,事件源类型非密码或单行、多行文本的,则退格键失效 
   var flag2 = ev.keyCode == 8 && t != "password" && t != "text" && t != "textarea";
   //判断 
   if (flag2 || flag1) return false;
}
//禁止后退键 作用于Firefox、Opera
document.onkeypress = forbidBackSpace;
//禁止后退键  作用于IE、Chrome
document.onkeydown = forbidBackSpace;

前台自动换行

#table_id * {
 text-align: center; 
 word-wrap:break-word;
 word-break:normal|break-all|keep-all;
 }

下载时,不同浏览器乱码问题解决(主要针对360极速模式以及兼容模式)

               response.setContentType("application/octet-stream");  
               boolean isMSIE = HttpUtils.isMSBrowser(request);  
               if (isMSIE) {  
	            //IE浏览器的乱码问题解决
                    fileName = URLEncoder.encode(fileName, "UTF-8");  
               } else {  
	            //万能乱码问题解决
                    fileName = new String(fileName.getBytes("UTF-8"), "ISO-8859-1");  
               }  
               response.setHeader("Content-disposition", "attachment;filename=\"" + fileName + "\"");  


public class HttpUtils {  
        private static String[] IEBrowserSignals = {"MSIE", "Trident", "Edge"};  
      
        public static boolean isMSBrowser(HttpServletRequest request) {  
            String userAgent = request.getHeader("User-Agent");  
            for (String signal : IEBrowserSignals) {  
                if (userAgent.contains(signal))  
                    return true;  
            }  
            return false;  
        }  
    }  

excel导入时间格式处理

//1、判断是否是数值格式  
if(cell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC){  
    short format = cell.getCellStyle().getDataFormat();  
    SimpleDateFormat sdf = null;  
    if(format == 14 || format == 31 || format == 57 || format == 58){  
        //日期  
        sdf = new SimpleDateFormat("yyyy-MM-dd");  
    }else if (format == 20 || format == 32) {  
        //时间  
        sdf = new SimpleDateFormat("HH:mm");  
    }  
    double value = cell.getNumericCellValue();  
    Date date = org.apache.poi.ss.usermodel.DateUtil.getJavaDate(value);  
    result = sdf.format(date);  
} 

你可能感兴趣的:(js,readonly后退,js)