Skip to content

ptylll/learn

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 

Repository files navigation

#前端学习地址

webpack

地址 地址
webpack中文网 webpack官网
col 2 is centered
zebra stripes are neat

vue

地址 地址
vue中文网 入门实例

css

地址 地址
偏门却又实用的 CSS 样式 CSS选择器速查表

js轮播图插件

地址 地址
兼容到IE6的轮播 兼容低版本浏览器的轮播插件
除去input代码点击灰色背
  * {
      -webkit-tap-highlight-color:rgba(0,0,0,0);
      -o-tap-highlight-color:rgba(0,0,0,0);
      -ms-tap-highlight-color:rgba(0,0,0,0);
      -moz-tap-highlight-color:rgba(0,0,0,0);/*ios点击有灰色背景*/

      }
user-select 禁止用户选中文本
    div {
        user-select: none; /* Standard syntax */
    }
-webkit-font-smoothing 字体抗锯齿

none ------ 对低像素的文本比较好 subpixel-antialiased ------默认值 antialiased ------抗锯齿很好

  div {
       -webkit-font-smoothing: antialiased; 
   }

要创建一个线性渐变,您需要设置一个起点和一个渐变的方向(或角度),并定义起止颜色。

-moz-linear-gradient( [<point> || <angle>,]? <stop>, <stop> [, <stop>]* )
css公用样式项目样式初始化
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins,
kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody,
tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time,
mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 14px;
    font-family: "Microsoft YaHei","微软雅黑","Helvetica Neue",Helvetica,"Hiragino Sans GB",Arial,sans-serif;
}
body,html{
    width: 100%;
    height:100%;
}
input:hover{
    opacity:0.9;
}
li{
    list-style: none;
}
a,input{outline:none;}
a{
    text-decoration: none;
    color:#333333;
}
a:hover{
    text-decoration: none;
}
*{
    padding: 0;
    margin:0; 
}
浏览器内核默认高版本控制
 <meta name="renderer" content="webkit">
 <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1" >
git本地代码提交仓库
gicle//初始化目录
git init 

//把所有内容添加到索引库中
$git add .

//同步线上库到本地(新添加项目)
$git pull --rebase origin master

//提交到本地仓库,分号中是针对要提交文件的描述
$git commit -m "随便写"

//如果远程origin已经存在,先删除远程origin,或者改用别的名字
$git remote rm origin

//关联远程仓库git
$git remote add origin [email protected]:名字/库名.git

//提交本地仓库到远程仓库主干中
$git push -u origin master

css hack

1.条件注释法
只在IE下生效 
<!--[if IE]> 
这段文字只在IE浏览器显示 
<![endif]--> 
只在IE6下生效 
<!--[if IE 6]> 
这段文字只在IE6浏览器显示 
<![endif]--> 
只在IE6以上版本生效 
<!--[if gte IE 6]> 
这段文字只在IE6以上(包括)版本IE浏览器显示 
<![endif]--> 
只在IE8上不生效 
<!--[if ! IE 8]> 
这段文字在非IE8浏览器显示 
<![endif]--> 
非IE浏览器生效 
<!--[if !IE]> 
这段文字只在非IE浏览器显示 
<![endif]--> 

######2.类内属性前缀法

“-″减号是IE6专有的hack 
“\9″ IE6/IE7/IE8/IE9/IE10都生效 
“\0″ IE8/IE9/IE10都生效,是IE8/9/10的hack 
“\9\0″ 只对IE9/IE10生效,是IE9/10的hack 
demo
    background-color:red; /* All browsers */  
    background-color:blue !important;/* All browsers but IE6 */  
    *background-color:black; /* IE6, IE7 */  
    +background-color:yellow;/* IE6, IE7*/  
    background-color:gray\9; /* IE6, IE7, IE8, IE9, IE10 */  
    background-color:purple\0; /* IE8, IE9, IE10 */  
    background-color:orange\9\0;/*IE9, IE10*/  
    _background-color:green; /* Only works in IE6 */  
    *+background-color:pink; /*  WARNING: Only works in IE7 ? Is it right? */ 
移动端
1.js根据屏幕宽度动态计算
!(function(doc, win) {
    var docEle = doc.documentElement,
        evt = "onorientationchange" in window ? "orientationchange" : "resize",
        fn = function() {
            var width = docEle.clientWidth;
            width && (docEle.style.fontSize = 20 * (width / 320) + "px");
        };
     
    win.addEventListener(evt, fn, false);
    doc.addEventListener("DOMContentLoaded", fn, false);
 
}(document, window));

2.视觉稿为 720 demo
!function(n){var e=n.document,t=e.documentElement,i=720,d=i/100,o="orientationchange"in n?"orientationchange":"resize",a=function(){var n=t.clientWidth||320;n>720&&(n=720),t.style.fontSize=n/d+"px"};e.addEventListener&&(n.addEventListener(o,a,!1),e.addEventListener("DOMContentLoaded",a,!1))}(window);

demo

<html>
<head>
    <script>
        var arr2 = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2];
        var arr3 = [1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2];
        function checkid() {
            var t = document.getElementById("gettext").value;
            if (t.length == 18) {
                console.log('11');
                var arr = t.split('');
                var s;
                var reg = /^\d+$/;
                var pd = 0;
                for (i = 0; i < 17; i++) {
                    if (reg.test(arr[i])) {
                        s = true;
                        pd = arr[i] * arr2[i] + pd;
                    } else {
                        s = false;
                        break;
                    }
                }
                if (s = true) {
                    var r = pd % 11;
                    if (arr[17] == arr3[r]) {
                        document.getElementById("show").innerHTML = "身份证号合法  尾号为:" + arr3[r];
                    } else {
                        document.getElementById("show").innerHTML = "非合法身份证号";
                    }
                }

            } else {
                document.getElementById("show").innerHTML = "非合法身份证号";
            }
        }
    </script>
</head>
<body>
    <input id="gettext" type="text"  size="30" onkeyup="checkid()"/>
        <p id ="show"></p><br>
</body>
</html>
placeholder兼容ie方法
	$(document).ready(function(){   
	   var doc=document,
	    inputs=doc.getElementsByTagName('input'),
	    supportPlaceholder='placeholder'in doc.createElement('input'),
	    
	    placeholder=function(input){
	     var text=input.getAttribute('placeholder'),
	     defaultValue=input.defaultValue;
	     if(defaultValue==''){
	        input.value=text
	     }
	     input.onfocus=function(){
	        if(input.value===text)
	        {
	            this.value=''
	        }
	      };
	     input.onblur=function(){
	        if(input.value===''){
	            this.value=text
	        }
	      }
	  };
	  
	  if(!supportPlaceholder){
	     for(var i=0,len=inputs.length;i<len;i++){
	          var input=inputs[i],
	          text=input.getAttribute('placeholder');
	          if(input.type==='text'&&text){
	             placeholder(input)
	          }
	      }
	  }
 });
css 素浮动造成容器的高度坍塌 解决办法
<Div class="div01">
	<div class="div02"></div>
</Div>
.div01{
	background-color: #ccc;
	min-height: 50px;
	padding: 10px;
}
.div02{
	height: 100px;
	width: 100px;
	padding: 20px;
	float: left;
	background-color: #999;
}
.div01::after{
	content: "";
	display: table;
	clear: both;
}
css3 fliter 十种特效
   grayscale灰度 把图片变成灰色 filter:grayscale(1); 值为 0 或 1
   sepia褐色  -webkit-filter:sepia(1);值为 0 或 1
   saturate饱和度  -webkit-filter:saturate(1); 默认为100% 1
   hue-rotate色相旋转 -webkit-filter:hue-rotate(90deg); 默认值为0deg
   invert反色 -webkit-filter:invert(1); 反色 默认为100%
   opacity透明度 -webkit-filter:opacity(.2); 默认值为100%
   brightness亮度 -webkit-filter:brightness(.5); 默认值为100%
   contrast对比度 -webkit-filter:contrast(2) 默认值:100%
   blur模糊 -webkit-filter:blur(3px); 默认值:0
   drop-shadow阴影 -webkit-filter:drop-shadow(5px 5px 5px #ccc)
flex 兼容性写法
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;

contenteditable属性 让元素可编辑
<div class="edit" contenteditable ="true">asdas</div>

contenteditable="plaintext-only"//让编辑区域只能键入纯文本
contenteditable="true"
contenteditable="false"

CSS实现单行、多行文本溢出显示省略号
1.
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;//行数
	overflow: hidden;
	//适用于手机
2.
	overflow: hidden;
	text-overflow:ellipsis;
	white-space: nowrap;
	
验证电话号 座机及手机号
function CheckTel() {
    /*验证电话号码 
    验证规则:区号+号码,区号以0开头,3位或4位号码由7位或8位数字组成 
    区号与号码之间可以无连接符,也可以“-”连接 
    如01088888888,010-88888888,0955-7777777 */
    var isPhone = /^0\d{2,3}-?\d{7,8}$/;
    /*验证手机号码
    移动:134(1349除外)135 136 137 138 139 147 150 151 152 157 158 159 182 183 184 187 188
    联通:130 131 132 155 156 185 186 145
    电信:133 153 177 180 181 189*/
    var isMob = /^((\+?86)|(\(\+86\)))?(13[012356789][0-9]{8}|15[012356789][0-9]{8}
	|18[02356789][0-9]{8}|147[0-9]{8}|1349[0-9]{7})$/;
    var value = $("#telphone").val();
    if (isMob.test(value) || isPhone.test(value)) {
        return true;
    }
    else {
        return false;
    }
}
js深拷贝
function DeepExtend(p,c){
	var c = c || {};
	for (var prop in p) {
		if(typeof p[prop] === "object"){
			c[prop] = (p[prop].constructor === Array) ? [] : {};
			DeepExtend(p[prop],c[prop]);
		}else{
			c[prop] = p[prop];
		}
	}
	return c;
}	
js 原生ajax封装
ajax({
	    url: "./TestXHR.aspx",              //请求地址
	type: "POST",                       //请求方式
	data: { name: "super", age: 20 },        //请求参数
	dataType: "json",
	success: function (response, xml) {
	    // 此处放成功后执行的代码
	},
	fail: function (status) {
	    // 此处放失败后执行的代码
	}
	});

	function ajax(options){
			options = options || {};
			options.type = (options.type || "get").topUpperCase();
			options.dataType = options.dataType || "json";
		var params = formatParams(options.data);

		if(window.XMLHttpRequest){//创建xhr
			var xhr = new XMLHttpRequest();
		}else{
			var xhr = ActiveXObject('Microsoft.XMLHTTP');
		}
	}

	//接收
	xhr.onreadystatechange=function(){
		if(xhr,readyState == 4){
			var status = xhr.status;
			if(status >= 200 && options.success(xhr.responseText,xhr.responseXML)){
				options.success && options.success(xhr.responseText,xhr.responseXML);
			}else{
				options.fail && options.fail(status);
			}
		}
	}
	//连接发送
	if(options.type =="GET"){
		xhr.open("GET",option.url+"?"+params,true);
		xhr.send(null);
	}else if(options.type =="POST"){
		xhr.open("POST",options.url,true);
		xhr.setRequestHeader("Content-Type","application/x-www-form-urllencoded");
		xhr.send(params);
	}
	//格式化参数
	function formatParams(data){
		var arr=[];
		for (var name in data) {
			arr.push(encodeURLCompontent(name)+"="+encodeURLCompontent(data[name]));
		}
		arr.push(("v="+Math.random()).replace(".",""));
		return arr.join("&");
	}
数组排序
function compare(val1,val2){
	if(val1 < val2){
		return -1;
	}else if(val1 > val2){
		return 1;
	}else{
		return 0;
	}
}
var a =[12,34,5,6,78,9,2,5,5,65,4,99];
a.sort(compare);
图片上传demo
function perveImg(file){
				
var div = document.getElementById('imgPerve');//预览图片div
var imgUp = document.getElementById('imgUp');//上传图片控件

	if(imgVerify(file)){
		if(file.files && file.files[0]){
			div.innerHTML = "<img id='imgHead'>";
			var img = document.getElementById('imgHead');
		    img.onload = function(){
				img.style.width="100%";
				img.style.height="100%";
			}
			var reader = new FileReader();//本地文件读入内存
			reader.onload = function(evt){
				img.src = evt.target.result;
			}
			reader.readAsDataURL(file.files[0]);
		}else{
		    imgUp.select();//IE指针
		    var imgSrc = document.selection.createRange().text;  
		div.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)";
	div.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = imgSrc;  
		}
	}else{
		return false;
	}
}
function imgVerify(file){//图片基本验证
	var fileSrc = file.value;//获取文件路径

	if(!fileSrc.match(/.jpg|.gif|.png|.bmp/i)){

		alert("请上传正确图片");

		file.value ="";

		return false;

	}else{
		if(!(file.files[0].size /1024/1024) > 1){

			alert("上传图片不能超过1M");

			file.value ="";

			return false;
		}else{
			return true;
		}
	}
}
jsonp demo
 function addScriptTag(src){
 	var script = document.createElement("script");
 	script.setAttribute("type","text/javascript");
 	script.src = src;
 	document.body.appendChild(script);
 }
 function myFn(data){
 	alert(data);
 }

 document.getElementById('jsonP').addEventListener("click",function(){
 	addScriptTag("http://bcp.baidu.com/news/access?callback = myFn");
 });	

vue

vue 获取当前对象 以及对象值(部分代码)
   <div id="wrap" class="wrap">
   	<div class="wrap-box" v-for="item in news">
   		<div class="wrap-left" :id='item.id' @click="show($event)">
   			<div class="wrap-img"><img :src='item.url'></div>
   			<div>{{item.title}}</div>
   		</div>
   	</div>
   </div>
   methods:{
   	show:function(event){
   		console.log(event.currentTarget);
   	}
   }

详见官网(https://cn.vuejs.org/v2/guide/events.html#方法事件处理器)

ES6 promise对象

1.对象的状态不受外界影响。Promise对象代表一个异步操作,有三种状态:Pending(进行中)、Resolved(已完成,又称 Fulfilled)和Rejected(已失败)  
2.一旦状态改变,就不会再变,任何时候都可以得到这个结果。

demo1:	var promise = new Promise(function(resolve, reject) {
	  // ... some code

	  if (/* 异步操作成功 */){
	    resolve(value);
	  } else {
	    reject(error);
	  }
	});

demo2: function timeout(ms) {
	  return new Promise((resolve, reject) => {
	    setTimeout(resolve, ms, 'done');
	  });
	}

	timeout(100).then((value) => {
	  console.log(value);
	});

js 验证变量是否为数组

 var a =[];
 
 Array.isArray(a);//true
 Object.Prototype.toString.call(a) === '[object Array]';
 
 综合: 
 	if(!Array.isArray){
		Array.isArray = function(arg){
			return  Object.Prototype.toString.call(a) === '[object Array]';
		}
	}

About

学习记录

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published