工做中遇到的一些問題和處理

一、名稱爲純英文數字等不換行問題

span {
    word-wrap: break-word;
    word-break: break-all;
} 複製代碼

二、各瀏覽器關於漸變色的適配

.main {
  background: linear-gradient(left, #055798, #01b1f8);
  background: -webkit-linear-gradient(left, #055798, #01b1f8);
  background: -ms-linear-gradient(left, #055798, #01b1f8);
  background: -moz--linear-gradient(left, #055798, #01b1f8);
  background: -0--linear-gradient(left, #055798, #01b1f8);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#055798', endColorstr='#01b1f8',GradientType=1 );//默認值,水平
  /*filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#055798', endColorstr='#01b1f8',GradientType=0 );//垂直*/
}複製代碼

三、內容太多需一行顯示,顯示不全的省略

span {
    display: block;
    height: 17px;
    overflow: hidden;
    white-space: nowrap;//一行顯示
    text-overflow: ellipsis;//顯示不全就省略
} 複製代碼

四、鼠標滾輪事件,各瀏覽器的適配

 連接地址:www.cnblogs.com/walkingp/ar…javascript

/*IE/Opera註冊事件*/
if(document.attachEvent){
     document.attachEvent('onmousewheel',scrollFunc);

}
/*Firefox註冊事件*/
if(document.addEventListener){
    document.addEventListener('DOMMouseScroll',scrollFunc,false);
}
/*Safari與Chrome屬於同一類型,可以使用HTML DOM方式添加事件*/
window.onmousewheel=document.onmousewheel=scrollFunc;//IE/Opera/Chrome

/*除Firefox外其他都可使用HTML DOM方式添加事件,所以添加事件使用如下方式*/
/*註冊事件*/
if(document.addEventListener){
    document.addEventListener('DOMMouseScroll',scrollFunc,false);
}//W3C
window.onmousewheel=document.onmousewheel=scrollFunc;//IE/Opera/Chrome複製代碼

五、上傳滾動條顯示問題

$.messager.progress({interval:'99999999'});			//緩衝進度條
var formData = new FormData();
var mutiUpload=document.getElementById('updateFile').files;
for(var i=0;i<mutiUpload.length;i++){
	formData.append("filelist", mutiUpload[i]);
}
formData.append("zyname", $("#addResource [name='zyname']").val());
formData.append("dagang", $("#addResource [name='dagang']").val());
formData.append("rangetype", $("#addResource [name='rangetype']").val());
formData.append("whether", $("#addResource [name='whether']").val());

$.ajax({
    url: webPath + '/wechat/Resourcesmanage/addListResources.htm',
    type: "POST",
    data: formData,
    processData: false, // 不要對data參數進行序列化處理,默認爲true
    contentType: false, // 不要設置Content-Type請求頭,由於文件數據是以 multipart/form-data 來編碼
    xhr: function(){
        myXhr = $.ajaxSettings.xhr();
        if(myXhr.upload){
          myXhr.upload.addEventListener('progress',function(e) {
            if (e.lengthComputable) {
              var percent = Math.floor(e.loaded/e.total*100);
              if(percent <= 100) {
                $(".progressbar-text").text(percent+'%');
                $(".progressbar-value").css('width', percent+'%');
              }
              if(percent > 100) {
              }
            }
          }, false);
        }
        return myXhr;//利用遞歸
    },
    success: function(obj){
        // 請求成功
    	var data=JSON.parse(obj);
		if(data.status==1){
			$.messager.progress('close');
			layerOpen('提示','添加成功!');
			//$('#win_add_Excel').window('close');
			$('.add-resource-file').fadeOut();
			$('.z_photo').html('');
			$('#addResource')[0].reset();
			initResources(pageNo,resSize,"","","");
		}else{
			$.messager.progress('close');
		     layerOpen('提示',data.msg);
		}
    },
    error: function(res) {
        // 請求失敗
        console.log(res);
    }
}); 複製代碼

六、IE6-IE8支持HTML5標籤

<!--[if lt IE 9]>
  <script src="//cdn.bootcss.com/respond.js/1.4.2/respond.js"></script>
   <script src="http://cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script>
<![endif]—>
//html5shiv:解決ie9如下瀏覽器對html5新增標籤的不識別,並致使CSS不起做用的問題。
//respond.min:讓不支持css3 Media Query的瀏覽器包括IE6-IE8等其餘瀏覽器支持查詢。複製代碼

 七、IE6 的塊級元素默認高度 bug

#dv_placeholder div {
    font: 1px/1 serif;  /** 清除塊默認高度 @ IE6 **/
}複製代碼

八、改變滾動條樣式

www.poluoluo.com/jzxy/201104/114964.html www.webhek.com/post/scroll…php

九、僞元素詳解

www.cnblogs.com/xiaohuochai…css

十、判斷 當前瀏覽器的型號、版本信息

blog.csdn.net/u011380927/…html

/**
 * 判斷 當前瀏覽器的型號、版本信息/* 須要jquery-migrate-1.2.1.min.js插件庫的支持
 */
function judgeBroswer() {
    if ($.browser.msie) {
        alert("this is msie! version:" + $.browser.version);
    } else if ($.browser.safari) {
        alert("this is safari! version:" + $.browser.version);
    } else if ($.browser.mozilla) {
        alert("this is mozilla! version:" + $.browser.version);
    } else if ($.browser.opera) {
        alert("this is opera version:" + $.browser.version);
    } else if ($.browser.chrome) {
        alert("this is chrome version:" + $.browser.version);
    }
} 複製代碼

十一、js的日期時間格式化

//日期格式化
'2016-06-17'.replace(/(\d{4})-(\d{2})-(\d{2})/g,'$1年$2月$3日')
"2016年06月17日";
//日期時間格式化
/**方法1**/
// 對Date的擴展,將 Date 轉化爲指定格式的String
// 月(M)、日(d)、小時(h)、分(m)、秒(s)、季度(q) 能夠用 1-2 個佔位符,
// 年(y)能夠用 1-4 個佔位符,毫秒(S)只能用 1 個佔位符(是 1-3 位的數字)
// 例子:
// (new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423
// (new Date()).Format("yyyy-M-d h:m:s.S")      ==> 2006-7-2 8:9:4.18
Date.prototype.Format = function (fmt) { //author: meizz
    var o = {
        "M+": this.getMonth() + 1, //月份
        "d+": this.getDate(), //日
        "h+": this.getHours(), //小時
        "m+": this.getMinutes(), //分
        "s+": this.getSeconds(), //秒
        "q+": Math.floor((this.getMonth() + 3) / 3), //季度
        "S": this.getMilliseconds() //毫秒
    };
    if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
    for (var k in o)
    if (new RegExp("(" + k + ")").test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
    return fmt;
}

調用:
var time1 = new Date().Format("yyyy-MM-dd");
var time2 = new Date().Format("yyyy-MM-dd hh:mm:ss");複製代碼
/**方法2**/
<script language="javascript" type="text/javascript">
<!-- /** * 對Date的擴展,將 Date 轉化爲指定格式的String * 月(M)、日(d)、12小時(h)、24小時(H)、分(m)、秒(s)、周(E)、季度(q)
    能夠用 1-2 個佔位符 * 年(y)能夠用 1-4 個佔位符,毫秒(S)只能用 1 個佔位符(是 1-3 位的數字) * eg: * (new
    Date()).pattern("yyyy-MM-dd hh:mm:ss.S")==> 2006-07-02 08:09:04.423
 * (new Date()).pattern("yyyy-MM-dd E HH:mm:ss") ==> 2009-03-10 二 20:09:04
 * (new Date()).pattern("yyyy-MM-dd EE hh:mm:ss") ==> 2009-03-10 週二 08:09:04
 * (new Date()).pattern("yyyy-MM-dd EEE hh:mm:ss") ==> 2009-03-10 星期二 08:09:04
 * (new Date()).pattern("yyyy-M-d h:m:s.S") ==> 2006-7-2 8:9:4.18
 */
Date.prototype.pattern=function(fmt) {
    var o = {
    "M+" : this.getMonth()+1, //月份
    "d+" : this.getDate(), //日
    "h+" : this.getHours()%12 == 0 ? 12 : this.getHours()%12, //小時
    "H+" : this.getHours(), //小時
    "m+" : this.getMinutes(), //分
    "s+" : this.getSeconds(), //秒
    "q+" : Math.floor((this.getMonth()+3)/3), //季度
    "S" : this.getMilliseconds() //毫秒
    };
    var week = {
    "0" : "/u65e5",
    "1" : "/u4e00",
    "2" : "/u4e8c",
    "3" : "/u4e09",
    "4" : "/u56db",
    "5" : "/u4e94",
    "6" : "/u516d"
    };
    if(/(y+)/.test(fmt)){
        fmt=fmt.replace(RegExp.$1, (this.getFullYear()+"").substr(4 - RegExp.$1.length));
    }
    if(/(E+)/.test(fmt)){
        fmt=fmt.replace(RegExp.$1, ((RegExp.$1.length>1) ? (RegExp.$1.length>2 ? "/u661f/u671f" : "/u5468") : "")+week[this.getDay()+""]);
    }
    for(var k in o){
        if(new RegExp("("+ k +")").test(fmt)){
            fmt = fmt.replace(RegExp.$1, (RegExp.$1.length==1) ? (o[k]) : (("00"+ o[k]).substr((""+ o[k]).length)));
        }
    }
    return fmt;
}

var date = new Date();
window.alert(date.pattern("yyyy-MM-dd hh:mm:ss"));
// -->
</script>

/**方法三**/
Date.prototype.format = function (mask) {
    var d = this;

    var zeroize = function (value, length) {

            if (!length) length = 2;

            value = String(value);

            for (var i = 0, zeros = ''; i < (length - value.length); i++) {

                zeros += '0';

            }

            return zeros + value;

        };

    return mask.replace(/"[^"]*"|'[^']*'|/b ( ? : d { 1, 4 } | m { 1, 4 } | yy( ? : yy) ? | ([hHMstT]) / 1 ? | [lLZ]) / b / g, function ($0) { switch ($0) { case 'd': return d.getDate(); case 'dd': return zeroize(d.getDate()); case 'ddd': return ['Sun', 'Mon', 'Tue', 'Wed', 'Thr', 'Fri', 'Sat'][d.getDay()]; case 'dddd': return ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'][d.getDay()]; case 'M': return d.getMonth() + 1; case 'MM': return zeroize(d.getMonth() + 1); case 'MMM': return ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'][d.getMonth()]; case 'MMMM': return ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'][d.getMonth()]; case 'yy': return String(d.getFullYear()).substr(2); case 'yyyy': return d.getFullYear(); case 'h': return d.getHours() % 12 || 12; case 'hh': return zeroize(d.getHours() % 12 || 12); case 'H': return d.getHours(); case 'HH': return zeroize(d.getHours()); case 'm': return d.getMinutes(); case 'mm': return zeroize(d.getMinutes()); case 's': return d.getSeconds(); case 'ss': return zeroize(d.getSeconds()); case 'l': return zeroize(d.getMilliseconds(), 3); case 'L': var m = d.getMilliseconds(); if (m > 99) m = Math.round(m / 10); return zeroize(m); case 'tt': return d.getHours() < 12 ? 'am' : 'pm'; case 'TT': return d.getHours() < 12 ? 'AM' : 'PM'; case 'Z': return d.toUTCString().match(/[A-Z]+$/); // Return quoted strings with the surrounding quotes removed default: return $0.substr(1, $0.length - 2); } }); };複製代碼

十二、window.url.createobjecturl 兼容多個瀏覽器

(IE,google,360,Safari,firefox)blog.csdn.net/ybb35068001… 前端

<script type="text/javascript">   
function setImagePreview() {
    var docObj = document.getElementById("ctl00_ContentMain_file_head");
    var fileName = docObj.value;
    if (!fileName.match(/.jpg|.gif|.png|.bmp/i)) {
        alert('您上傳的圖片格式不正確,請從新選擇!');
        return false;
    }

    var imgObjPreview = document.getElementById("preview");
    if (docObj.files && docObj.files[0]) {
        //火狐下,直接設img屬性   
        imgObjPreview.style.display = 'block';
        imgObjPreview.style.width = '63px';
        imgObjPreview.style.height = '63px';
        //imgObjPreview.src = docObj.files[0].getAsDataURL();   
        if (window.navigator.userAgent.indexOf("Chrome") >= 1 || window.navigator.userAgent.indexOf("Safari") >= 1) {
            imgObjPreview.src = window.webkitURL.createObjectURL(docObj.files[0]);
        } else {
            imgObjPreview.src = window.URL.createObjectURL(docObj.files[0]);
        }
    } else {
        //IE下,使用濾鏡   
        docObj.select();
        docObj.blur();
        var imgSrc = document.selection.createRange().text;
        var localImagId = document.getElementById("localImag");
        //必須設置初始大小   
        localImagId.style.width = "63px";
        localImagId.style.height = "63px";
        //圖片異常的捕捉,防止用戶修改後綴來僞造圖片   
        try {
            localImagId.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)";
            localImagId.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = imgSrc;
        } catch(e) {
            alert("您上傳的圖片格式不正確,請從新選擇!");
            return false;
        }
        imgObjPreview.style.display = 'none';
        document.selection.empty();
    }
    return true;
}  
  
</script>   

<div id="localImag"><img id="preview" width="-1" height="-1" style="display:none" /></div> 
<asp:FileUpload ID="file_head" runat="server" onchange="javascript:setImagePreview();" /> 


//http://blog.csdn.net/qq_24148225/article/details/53187149?locationNum=5&fps=1
if(navigator.userAgent.indexOf("MSIE 9.0")>0){//判斷ie瀏覽器版本  
     var pic = document.getElementById("showLogo"),  
     file = document.getElementById("logo");  
     file.select();  
  
//因爲ie9的安全性,若沒有focus()聚焦到其餘button,div等,document.selection.createRange().text將會報錯  
//(這裏的save是一個button,若focus到div這個div須要至少有1px)  
      document.getElementById("save").focus();  
      //file.blur();  
      var reallocalpath = document.selection.createRange().text;  
      pic.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale',src=\"" + reallocalpath + "\")";//增長濾鏡  
//這裏設置預覽圖片pic的大小  
      pic.style.width = "180px";  
      pic.style.height = "130px";  
// 設置img的src爲base64編碼的透明圖片 取消顯示瀏覽器默認圖片  
      pic.src = '';  
  
}else{  
     //其餘瀏覽器  
     document.getElementById("showLogo").src =getFileUrl("logo");   
  
}  
  
  
function getFileUrl(fileName){  
     var url ;             
     if (navigator.userAgent.indexOf("MSIE")>=1) {  
          url = document.getElementById(sourceId).value; // IE10,11可使用這種方式  
     } else if(navigator.userAgent.indexOf("Firefox")>0) { // Firefox  
          url = window.URL.createObjectURL(document.getElementById(fileName).files.item(0));  
     } else if(navigator.userAgent.indexOf("Chrome")>0) { // Chrome  
          url = window.URL.createObjectURL(document.getElementById(fileName).files.item(0));  
     } else{  
          url = window.URL.createObjectURL(document.getElementById(fileName).files.item(0));  
     }  
     return url;  
  
}複製代碼

1三、禁止右鍵及複製粘貼事件

//http://www.cnblogs.com/ZDPPU/p/5950408.html  html5

oncontextmenu事件單禁用右鍵菜單 一個頁面中,BODY中用oncontextmenu='return false'來取消鼠標右鍵;在JS中設置oncontextmenu='return true'window.document.oncontextmenu = function(){ return false;}java

onconTextmenu=window.event.returnValue=false;右鍵菜單禁用,用這個能夠禁止複製。jquery

在<body>中加入屬性代碼: css3

oncontextmenu="return false"

onselectstart="return false"     //禁止選中網頁上的內容

oncopy="return false"            //防複製用戶在網頁上選中的內容

複製代碼

防止用戶另存網頁: 利用<noscript><iframe src=*.html></iframe></noscript>標籤,能防止網頁的直接另存,但不能防止網頁被人使用工具下載 git

 *爲通配符。 

例1: 

<html>
<head>
<title>OnContextMenu事件</title>

<script language="JavaScript">
<!--

function uFunction()

{     document.all.infoDiv.innerHTML='你按下了鼠標右鍵,可是右鍵菜單不能 顯示!';}

function uFunction2()

{    document.all.infoDiv.innerHTML='你按下了Ctrl+鼠標右鍵,能夠 顯示右鍵菜單。';}

//-->

</script>
</head>

<body oncontextmenu="if(!event.ctrlKey){uFunction();return false}else{uFunction2()}">

<div id="infoDiv">你按下了鼠標右鍵,可是右鍵菜單不能 顯示!<br>你按下了Ctrl+鼠標右鍵,能夠顯示右鍵菜單。
</div></body>
</html>複製代碼

 

//禁用鼠標事件
document.onmousedown = function(e){
    if ( e.which == 2 ){// 鼠標滾輪的按下,滾動不觸發
        return false;
    }
    if( e.which==3 ){// 鼠標右鍵
        return false;
    }
}

//禁用鍵盤中的ctrl、alt、shift
document.onkeydown = function(){
    if( event.ctrlKey ){
        return false;
    }
    if ( event.altKey ){
        return false;
    }
    if ( event.shiftKey ){
        return false;
    }
}

oncontextmenu='return false'
ondragstart='return false'
onselectstart ='return false'
onselect='document.selection.empty()'
oncopy='document.selection.empty()'
onbeforecopy='return false'
onmouseup='document.selection.empty()' 複製代碼

一個更簡單的方法就是在<body>中加入以下的代碼,這樣鼠標的左右鍵都失效了. 

topmargin="0"
oncontextmenu="return false" 
ondragstart="return false" 
onselectstart="return false" 
onselect="document.selection.empty()"
oncopy="document.selection.empty()" 
onbeforecopy="return false"
onmouseup="document.selection.empty()"

//1.禁止網頁另存爲:在<body>後面加入如下代碼:
<noscript>
<iframe src="*.htm"></iframe>
</noscript>


//2.禁止網頁內容複製.粘貼:在<body>中加入如下代碼:
<body
onmousemove=/HideMenu()/ oncontextmenu="return false"
ondragstart="return false" onselectstart ="return false"
onselect="document.selection.empty()"
oncopy="document.selection.empty()" onbeforecopy="return false"
onmouseup="document.selection.empty()">複製代碼

 1四、一個可編輯div中粘貼內容時過濾掉粘貼內容的一些特殊的樣式或者標籤

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
  
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>無標題文檔</title>
  </head>
  
  <body>
    <div id="test" style="float: left; height: 100px; width: 500px; border:1px solid red" contenteditable="true" class="testmr">2222</div>
  </body>

</html>
<script type="text/javascript" src="js/jquery.js"></script>
<script type="text/javascript">
$(function(){

   var update = function(original){
   var new_content = $('.testmr').html();

   var new_content = new_content.replace(/class="[^"]+"/ig, ''); new_content = new_content.replace(/class\="[^"]+"/gi, '');

   new_content = new_content.replace(/<h1.*?>(.*?)<\/h1>/ig,"$1");

   new_content = new_content.replace(/<h2.*?>(.*?)<\/h2>/ig,"$1");

   new_content = new_content.replace(/<h3.*?>(.*?)<\/h3>/ig,"$1");

   new_content = new_content.replace(/<h4.*?>(.*?)<\/h4>/ig,"$1");

   new_content = new_content.replace(/<h5.*?>(.*?)<\/h5>/ig,"$1");

   new_content = new_content.replace(/<h6.*?>(.*?)<\/h6>/ig,"$1");

   new_content = new_content.replace(/style\="[^"]+"/gi, ''); alert(new_content); $('.testmr').html(new_content); } $('.testmr').bind('paste',function(e){ var $this = $(this); var original = $this.html(); setTimeout(function(){update();}, 10); }) }) </script>複製代碼

1五、圖片上傳/預覽

function updateImage(obj,showid){
	var idFile = $(obj).attr("id");
    var docObj = document.getElementById(idFile);
    var fileName  = docObj.value; //獲取的文件
    if (!fileName.match(/.jpg|.gif|.png|.jpeg/i)) {
    	layerOpen('提示','您上傳的圖片格式不正確,請從新選擇!');
    	return false;
    }
    var imgSrc='';
    if (docObj.files && docObj.files[0]) {
    	//火狐下,直接設img屬性
    	/*imgSrc = docObj.files[0].getAsDataURL();   */
    	if (window.navigator.userAgent.indexOf("Chrome") >= 1 || window.navigator.userAgent.indexOf("Safari") >= 1) {
    		imgSrc = window.webkitURL.createObjectURL(docObj.files[0]);
    	}
    	else {
    		imgSrc = window.URL.createObjectURL(docObj.files[0]);
    	}
    } else {
    	imgSrc= fileName;
    }
    if(navigator.userAgent.indexOf("MSIE 9.0")>0){//判斷ie瀏覽器版本
        var pic = document.getElementById(showid),
        file = document.getElementById(idFile);
        file.select();
        file.blur();
         var reallocalpath = document.selection.createRange().text;
         pic.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale',src=\"" + reallocalpath + "\")";//增長濾鏡
   //這裏設置預覽圖片pic的大小
   // 設置img的src爲base64編碼的透明圖片 取消顯示瀏覽器默認圖片
         pic.src = '';
   }
   /*var imgUrl = window.URL.createObjectURL(fileList[0]);*/
   $(obj).next().attr("src",imgSrc);
}

function addAppIndex(){
	if (!standard_checkInputInfo("addAppForm")) {
		return;
	}
	if(''==$('#addAppImg').val()){
		layerOpen('提示','請上傳圖片');
		return;
	}
	$('#addAppForm').form('submit', {
		url : function() {
			return webPath + '/wechat/homeconfiguration/addHomeconfiguration.htm';
		},
		success : function(data) {
			var dataObj = eval("(" + data + ")");
			if (dataObj.status == 1) {
				$('#addAppForm')[0].reset();
				loadParentAPP(pageNo,quesSize);
				$('.add-app').fadeOut();
				layerOpen('提示',dataObj.msg);
			}else{
				layerOpen('提示',dataObj.msg);
			}
		}
	});
}複製代碼

1六、某些CSS樣式

overflow: hidden; /**自動隱藏文字*/
text-overflow: ellipsis; /**文字隱藏後添加省略號*/
white-space: nowrap; /**強制不換行*/
word-wrap: normal(默認) | break-word/*打斷,強制換行*/
word-break: normal(默認) | break-all | keep-all /*Firefox、Opera不能識別*/

/*不讓鼠標選中文字*/
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
user-select: none;複製代碼

1七、用JS判斷操做系統,只能手機登陸,而電腦不能登陸Web

/**
 *用JS判斷操做系統 若是不是手機客戶端直接跳轉到一個顯示頁面 提示 
 */
<script type="text/javascript">
  var ua = window.navigator.userAgent;
  var osVersion = ua.split(";")[2];
  var osV = osVersion.substr(osVersion.length - 3, 3);
  switch (osV) {
  case "5.0":
    document.write("Win2000");
    break;
  case "5.1":
    document.write("WinXP");
    break;
  case "5.2":
    document.write("Win2003");
    break;
  default:
    document.write("Others");
    break;
  }
</script>複製代碼

1八、微信JS支付代碼_前端調用微信支付接口 

//1.跟你們分享一段微信支付的js代碼片斷、V3版的微信支付沒有paySignKey參數、基本上是直接複製就可使用了、改一改本身的參數就行了、話很少說、直接上代碼
$(´.Save_Patient_Msg´).click(function(){
    $(´.Save_Patient_Msg´).off(´click´);
    var hrdfId = getOrderId();
    var txnAmt = $(´.sum_pay.font-red´).html(); 
     
    var data = {orderId: hrdfId, txnAmt: "0.01", 
        prodDesc: "遠程診斷服務", callType: "JSAPI",
        access_token: getUrlParam("access_token")
    };

    $.ajax({
        type: ´POST´,
        url: ´/hims/api/commonPay/queryTransNo?access_token=´ getUrlParam(´access_token´),
        dataType:´json´,
        contentType:´application/json´,
        data: JSON.stringify(data),
        success: function(Wxres){
          if(!Wxres){
            $.alert(´服務器擁堵,請稍後訪問´)
          }else{
              console.log(Wxres);
              if(Wxres.data.respCode == ´fail´){
                $.alert(Wxres.data.respMsg);
              }else{
                 //10 微信支付接口
                    // 10.1 發起一個支付請求
                    // 注意:此 Demo 使用 2.7 版本支付接口實現,建議使用此接口時參考微信支付相關最新文檔。
                    var param = Wxres.data;
                    wx.config({
                        debug: false, // 開啓調試模式,調用的全部api的返回值會在客戶端alert出來,若要查看傳入的參數,能夠在pc端打開,參數信息會經過log打出,僅在pc端時纔會打印。
                        appId: ´wx403ead26691402fb´, // 必填,公衆號的惟一標識
                        timestamp: param.timestamp, // 必填,生成簽名的時間戳
                        nonceStr: param.noncestr, // 必填,生成簽名的隨機串
                        signature: param.signJs,// 必填,調用js簽名,
                        jsApiList: [´chooseWXPay´] // 必填,須要使用的JS接口列表,這裏只寫支付的
                    });
                    wx.chooseWXPay({
                        timestamp: param.timestamp, // 支付簽名時間戳,注意微信jssdk中的全部使用timestamp字段均爲小寫。但最新版的支付後臺生成簽名使用的timeStamp字段名需大寫其中的S字符
                        nonceStr: param.noncestr, // 支付簽名隨機串,不長於 32 位
                        package: "prepay_id=" param.transNo, // 統一支付接口返回的prepay_id參數值,提交格式如:prepay_id=***)
                        signType: "MD5", // 簽名方式,默認爲´SHA1´,使用新版支付需傳入´MD5´
                        paySign: param.sign, // 支付簽名
                        success: function (res) {
                            if(res.errMsg == "chooseWXPay:ok"){
                                //alert("支付成功");
                                window.location.href  = "/hims/weixin/pages/Order_ok.html?access_token=" getUrlParam("access_token");
                            }else{
                                alert(res.errMsg);
                            }
                        },
                        cancel: function(res){
                            //alert(´取消支付´);
                        }
                    });
                }
            }   
        },
        error:function(data){
            var msg =  data.message || data.status;
            $.alert(´服務器錯誤´ msg);
        }
    });   
    return false;
});




function getUrlParam(name){
    //構造一個含有目標參數的正則表達式對象
    var reg = new RegExp("(^|&)"  name  "=([^&]*)(&|$)");
    //匹配目標參數
    var r = window.location.search.substr(1).match(reg);
    //返回參數值
    if (r!=null) return unescape(r[2]); return null;
}


連接:
http://dditblog.com/itshare_553.html
http://www.cnblogs.com/kewenxin/p/7463337.html



//2.微信支付主要就是三步:1.組裝數據生成預支付ID,2.調起微信支付接口,3.結果處理
$("#getBrandWCPayRequest").click(function() {
    $.ajax({
        type: "POST",
        url: "",
        data: {
            "openId": $("#openId").val(),
            "total_fee": $("#total_price").html(),
            "body": $("#bodydes").html(),
            "productid": $("#productid").val()
        },
        //參數本身根據業務定義  
        dataType: "json",
        success: function(data) {
            callPay(data);
        }
    });
});

function callPay(data) {
    //alert("回調執行");  
    var appId = data.appId;
    var timeStamp = data.timeStamp;
    var nonceStr = data.nonceStr;
    var package = data.package;
    var signType = data.signType;
    var paySign = data.paySign;
    //  
    WeixinJSBridge.invoke('getBrandWCPayRequest', {
        "appId": appId,
        "timeStamp": timeStamp,
        "nonceStr": nonceStr,
        "package": package,
        "signType": signType,
        "paySign": paySign

    },
    function(res) {
        //alert(res.err_msg);  
        WeixinJSBridge.log(res.err_msg);
        if (res.err_msg == "get_brand_wcpay_request:ok") {
            //var pc = data.total_fee;  
            //var body = data.body;  
            //var openId = data.openId;  
            //var timeStamp = data.timeStamp;  
            //alert("交易金額:"+pc+"分錢"+"產品名稱:"+body+"用戶openID:"+openId+"訂單號:2015"+timeStamp);  
            //alert("支付成功!");  
            WeixinJSBridge.call('closeWindow');
        } else if (res.err_msg == "get_brand_wcpay_request:cancel") {
            //alert("用戶取消支付!");  
            //WeixinJSBridge.call('closeWindow');  
        } else {
            alert("支付失敗!");
            WeixinJSBridge.call('closeWindow');
        }
    });

}複製代碼

blog.csdn.net/yulei_qq/ar… 銀聯支付 blog.csdn.net/Angular_/ar… mui微信/支付寶支付js 

1九、複製粘貼時自動添加出處

<script type="text/javascript">
document.body.oncopy = function () {
setTimeout( function () { 
    var text = clipboardData.getData("text"); 
    if (text) { 
        text = text + "\r\n\r\n原文地址:"+location.href; 
        clipboardData.setData("text", text); 
    } 
}, 100 );
};
</script>複製代碼

 JavaScript在複製粘貼網頁內容時自動添加出處: 

www.open-open.com/code/view/1420709972656 

outofmemory.cn/code-snippet/633/javascript-fuzhiniantie-wangyeneirong-shi-zidong-augment-chuchu 

20、json字符串和json對象互轉

www.jb51.net/article/350… 

JSON.parse(jsonstr); //能夠將json字符串轉換成json對象 
JSON.stringify(jsonobj); //能夠將json對象轉換成json對符串複製代碼

2一、Truthy

在JavaScript中,Truthy(真值)指的是在Boolean上下文中轉換後的值爲真的值。全部值都是真值,除非它們被定義爲 falsy (即, 除了false,0,「」,null,undefined和NaN 外)。 JavaScript 在Boolean上下文中使用強制類型轉換(coercion)。 

2二、時間格式化

function show(date) {
    var date = new Date(date);
    /*var info = date.getFullYear()+"年";*/
    var info = date.getMonth() + 1 + "月";
    info += date.getDate() + "日";
    info += date.getHours() + "時";
    info += date.getMinutes() + "分";
    return info;
}複製代碼

 moment.js momentjs.cn/ 

2三、30-seconds-of-code 代碼片斷

30-seconds-of-code

github.com/Chalarangelo/30-seconds-of-code#anagrams-of-string-with-duplicates http://mp.weixin.…

2四、ajax的jquery同步/異步

Ajax請求默認的都是異步的 若是想同步 async設置爲false就能夠(默認是true) var html = $.ajax({ url: "some.php", async: false }).responseText; 或者在全局設置Ajax屬性 $.ajaxSetup({ async: false }); 再用post,get就是同步的了 

2五、如何判斷當前瀏覽器是什麼瀏覽器?

延伸擴展:如何判斷當前瀏覽器是什麼瀏覽器?   

      簡而言之,每一個瀏覽器的獨有屬性的一個羅列:   

      總所周知:當下比較經常使用的有Firefox(火狐瀏覽器)、Opera(歐鵬瀏覽器)、Safari(蘋果公司的網絡瀏覽器)、Chrome(谷歌瀏覽器);下面一一對各個瀏覽器相對獨有的特性進行一個描述(暫時不談論內核的差距,主要是從相關函數進行分析)。   

      Firefox中的DOM元素都有一個getBoxObjectFor函數,用來獲取該DOM元素的位置和大小(IE對應的中是getBoundingClientRect函數)。這是Firefox獨有的,判斷它便可知道是當前瀏覽器是Firefox。   

      Opera提供了專門的瀏覽器標誌,就是window.opera屬性。   

      Safari瀏覽器中有一個其餘瀏覽器沒有的openDatabase函數,可作爲判斷Safari的標誌。

    Chrome有一個MessageEvent函數,但Firefox也有。不過,好在Chrome並無Firefox的getBoxObjectFor函數,根據這個條件仍是能夠準確判斷出Chrome瀏覽器的。

2六、byte的1024轉換方法

function bytesToSize(bytes) {  
    if (bytes === 0) return '0 B';  
    var k = 1024, // or 1000  
        sizes = ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'],  
        i = Math.floor(Math.log(bytes) / Math.log(k));  
  
    return (bytes / Math.pow(k, i)).toFixed(1) + ' ' + sizes[i];  
} 複製代碼

2七、JS獲取URL中參數值(QueryString)的4種方法

方法一:正則法 

function getQueryString(name) {
    var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');
    var r = window.location.search.substr(1).match(reg);
    if (r != null) {
        return unescape(r[2]);
    }
    return null;
}
// 這樣調用:
alert(GetQueryString("參數名1"));
alert(GetQueryString("參數名2"));
alert(GetQueryString("參數名3"));複製代碼

方法二:split拆分法 

function GetRequest() {
    var url = location.search; //獲取url中"?"符後的字串
    var theRequest = new Object();
    if (url.indexOf("?") != -1) {
        var str = url.substr(1);
        strs = str.split("&");
        for (var i = 0; i < strs.length; i++) {
            theRequest[strs[i].split("=")[0]] = unescape(strs[i].split("=")[1]);
        }
    }
    return theRequest;
}
var Request = new Object();
Request = GetRequest();
//    var 參數1,參數2,參數3,參數N;
//     參數1 = Request['參數1'];
//     參數2 = Request['參數2'];
//     參數3 = Request['參數3'];
//     參數N = Request['參數N'];
var q;
q = Request['q'];
q = Request.q;複製代碼

方法三:又見正則  

function GetQueryString(name) {
    var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
    var r = window.location.search.substr(1).match(reg); //獲取url中"?"符後的字符串並正則匹配
    var context = "";
    if (r != null) context = r[2];
    reg = null;
    r = null;
    return context == null || context == "" || context == "undefined" ? "": context;
}
alert(GetQueryString("q"));複製代碼

方法四:單個參數的獲取方法 

function GetRequest() {
    var url = location.search; //獲取url中"?"符後的字串
    if (url.indexOf("?") != -1) { //判斷是否有參數
        var str = url.substr(1); //從第一個字符開始 由於第0個是?號 獲取全部除問號的全部符串
        strs = str.split("="); //用等號進行分隔 (由於知道只有一個參數 因此直接用等號進分隔 若是有多個參數 //要用&號分隔 再用等號進行分隔)
        alert(strs[1]); //直接彈出第一個參數 (若是有多個參數 還要進行循環的)
    }
}複製代碼

2八、得到瀏覽器版本信息

function getBroswer(){
    var sys = {};
    var ua = navigator.userAgent.toLowerCase();
    var s;
    (s = ua.match(/edge\/([\d.]+)/)) ? sys.edge = s[1] :
    (s = ua.match(/rv:([\d.]+)\) like gecko/)) ? sys.ie = s[1] :
    (s = ua.match(/msie ([\d.]+)/)) ? sys.ie = s[1] :
    (s = ua.match(/firefox\/([\d.]+)/)) ? sys.firefox = s[1] :
    (s = ua.match(/chrome\/([\d.]+)/)) ? sys.chrome = s[1] :
    (s = ua.match(/opera.([\d.]+)/)) ? sys.opera = s[1] :
    (s = ua.match(/version\/([\d.]+).*safari/)) ? sys.safari = s[1] : 0;

    if (sys.edge) return { broswer : "Edge", version : sys.edge };
    if (sys.ie) return { broswer : "IE", version : sys.ie };
    if (sys.firefox) return { broswer : "Firefox", version : sys.firefox };
    if (sys.chrome) return { broswer : "Chrome", version : sys.chrome };
    if (sys.opera) return { broswer : "Opera", version : sys.opera };
    if (sys.safari) return { broswer : "Safari", version : sys.safari };
    
    return { broswer : "", version : "0" };
}	
getBroswer();複製代碼

2九、firefox hack

@-moz-document url-prefix(){.input2{top:2px;}}複製代碼

30、json js對象 js字符串轉換 

 jquery-json 

var thing = {plugin: 'jquery-json', version: 2.3};//js對象

var encoded = $.toJSON( thing );
//轉換爲json,結果: '{"plugin":"jquery-json","version":2.3}'

var name = $.evalJSON( encoded ).plugin;
//js對象.屬性,結果: "jquery-json"

var version = $.evalJSON(encoded).version;
//結果: 2.3複製代碼

3一、避免瀏覽器自動填充表單的解決方式

www.cnblogs.com/moonLightcy… 

一、添加input隱藏框來填充 

<input name="old-userName" type="text">
<input name="old-pwd" type="password">
<ul class="ul-info">
    <li><label>帳號:</label>
          <input id="userName" type="text">
    </li>
    <li><label>密碼:</label>
      <input class="0" type="password">
    </li>
</ul> 複製代碼

 二、修改選擇器 

<li><label>帳號:</label>
<input id="a" type="text">
</li>
<li><label>密碼:</label>
    <input type="password">
</li> 複製代碼

這種方式是我本身閒着無聊,試着玩兒試出來的,感受這種方式仍是比較合理的,畢竟DOM那麼金貴,不須要多餘的input,這種方式須要注意的幾點就是: 

    1)、必定要給type='text'一個id; 

    2)、type='password'不能有id或者name(有其一都會致使自動填充),能夠有class; 

    3)、目測這種方式在360上行不通,谷歌沒有問題,謹慎; 

三、使用js控制 

附加一個小提示:若是隻是想要去掉那個黃色的背景保留填充的值的話,如下兩種css樣式取其一,都是能夠作到的,由於咱們改的樣式不在用戶代理樣式表裏面。

input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px white inset !important;
}
input:-webkit-autofill {
   transition: background-color 5000s ease-in-out 0s;
} 複製代碼

3二、面試題綜合

juejin.im/entry/58abd… https://juejin.im/entry/58ba33a5570c350062125431 https://juejin.im/entry/59b3b5ecf265da0652707150 https://juejin.im/entry/59ffce6df265da43052e016b 

3三、在html的頭部加入meta使得全部的資源請求由http請求轉成https請求

<meta http-equiv="Content-Security-Policy" content="upgrade-insecure-requests">複製代碼

3四、設置雙核瀏覽器的瀏覽模式

<meta name="renderer" content="webkit|ie-comp|ie-stand"> 

content的取值爲webkit,ie-comp,ie-stand之一,區分大小寫,分別表明用webkit內核,IE兼容內核,IE標準內核。 

若頁面需默認用極速核,增長標籤:<meta name="renderer" content="webkit">

若頁面需默認用ie兼容內核,增長標籤:<meta name="renderer" content="ie-comp"> 

若頁面需默認用ie標準內核,增長標籤:<meta name="renderer" content="ie-stand"> 

3五、ie最高版本

<meta http-equiv="X-UA-Compatible" content="IE=EDGE"> 複製代碼

3六、兩端對齊用法

www.cnblogs.com/reaf/p/6795…

連接中的方法更全面

<style>
    p{
        margin: 0;
        font-size: 12px;
    }
    .justify{
        text-align: justify;
        height: 20px;
        width:50px;
    }
    .justify:after{
        content:'.';
        width: 100%;
        display: inline-block;
        overflow: hidden;
        height: 0;
    }
</style><body>
<div style="width: 150px;">
    <div style="overflow: hidden;">
        <p class="justify" style="float: left;">星上時</p>
        <p style="float: left;">:2018-10-19</p>
    </div>
    <div style="overflow: hidden;">
        <p class="justify" style="float: left;">GNC時</p>
        <p style="float: left;">:2018-10-19</p>
    </div>
</div>
</body>複製代碼

上面的代碼測了下 谷歌能夠 ie不支持

3七、打印功能相關

 1.解決 Webkit 瀏覽器下打印網頁須要手工設置 "打印背景色" 的問題: 好比說一個元素有個背景顏色, 在打印的時候默認瀏覽器是不打印背景圖和背景色的. 若要打印, 須要在元素的樣式上添加如下代碼: -webkit-print-color-adjust: exact; 這樣 WebKit 瀏覽器中 不管是否勾選 "打印背景圖和背景色", 背景圖和背景色都會被打印出來。IE下無效 

3八、屏蔽瀏覽器返回按鈕

window.history.pushState('aa', document.URL);
window.addEventListener('popstate', function () {
	history.pushState('aa', document.URL);
}, false);複製代碼
相關文章
相關標籤/搜索