本文僅記錄本人學習知識,文章出現的題目都是轉載網絡的。互相學習,一塊兒成長!
var arr = new Array(5); function insertRandom(n) { if (n < 0) return let tmp = Math.floor(Math.random() * 31 + 2) if (arr.indexOf(tmp) !== -1) return insertRandom(n) arr[n] = tmp return insertRandom(n - 1) } insertRandom(arr.length - 1)
語法:css
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <style> main { width: 100%; padding: 60px 80px 80px; background: #b4a078; } div { padding: 12px; margin: 20px auto; background: white; border: 10px solid hsla(0, 0%, 100%, .5); background-clip: padding-box; } label {color: #f4f0ea;} </style> <body> <main> <div>A paragraph of filler text. La la la de dah de dah de dah de la.</div> </main> </body> </html>
語法:html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <style> main{ width: 100%; padding: 0; display: flex; flex-wrap: wrap; justify-content: space-around; align-items: center; } div:nth-of-type(1) { width: 60px; height: 60px; border-radius: 50%; background: #fafafa; margin: 105px 29px; box-shadow: 0 0 0 10px #E8E2D6, 0 0 0 20px #E1D9C9, 0 0 0 30px #D9CFBB, 0 0 0 40px #D2C6AE, 0 0 0 50px #CABCA0, 0 0 0 60px #C3B393, 0 0 0 70px #BBA985, 0 0 0 80px #B4A078; } div:nth-of-type(2){ width: 200px; height: 120px; background: #efebe9; border: 5px solid #B4A078; outline: #B4A078 dashed 1px; outline-offset: -10px; margin-bottom: 20px; } </style> <body> <main> <div></div> <div></div> </main> </body> </html>
語法:html5
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <style> main {width: 100%;} div { width: 209px; margin: 29px auto; padding: 8px 16px; border-radius: 8px; background: #f4f0ea; outline: 6px solid #b4a078; box-shadow: 0 0 0 5px #b4a078; } </style> <body> <main> <div>例子</div> </main> </body> </html>
語法:正則表達式
.el { margin-left: calc(10% + 10px); //將元素的左邊距指定爲其父級寬度的 「10%」 加上額外的 「10px」; margin-left: calc(10% - 10px); //將元素的左邊距指定爲其父級寬度的 「10%」 減去額外的 「10px」: }
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <style> main { width: 100%; padding: 80px 0px; display: flex; flex-wrap: wrap; justify-content: space-around; } div { width: 229px; height: 139px; margin: auto; color: #f4f0ea; padding: 16px 29px 28px 20px; background: #b4a078 url('') no-repeat bottom right / 78px 21px; } div:nth-of-type(1) { background-position: right 29px bottom 28px; } div:nth-of-type(2) { background-origin: content-box; margin: 29px 0; } div:nth-of-type(3) { background-position: calc(100% - 29px) calc(100% - 28px); } </style> <body> <main> <div class="block1">background-position方案</div> <div class="block2">background-origin方案</div> <div class="block3">calc方案</div> </main> </body> </html>
塊級元素:算法
名稱 | 做用 | 名稱 | 做用 |
---|---|---|---|
head | div | ||
meat | 申明頁面的諸多屬性 | ul | |
title | 窗口標題 | li | |
style | 樣式 | ol | |
body | 文本內容 | p | |
header | 頭部塊 | dl | |
section | 內容塊 | dt | |
footer | 底部塊 | dd | |
article | 文章標籤 | form | |
hr | 下劃線 | table | |
h1-h6 | 描述標題 | theader | |
aside | tbody | ||
nav | tr | ||
menu | th | ||
bir |
行內元素:json
名稱 |
---|
label |
a |
span |
td |
input |
button |
strong |
b |
i |
邊框(borders):api
背景:跨域
漸變:數組
文本效果:瀏覽器
2D轉換屬性
2D轉換方法
3D轉換屬性:
3D轉換方法
過渡
動畫
實現思路:用正則表達式中的replace方法匹配,'s'是指空白符(包括空格,換行符,回車符,換頁符,製表符等);<br/>
若是正則表達式不太明白的掘友,能夠查看我以前寫過有關正則表達式的我的總結篇
var trim = function(str){ str.replace(/\s*/g,""); //去除字符串內全部的空格 str.replace(/^\s*|\s*$/g,""); //去除字符串內兩頭的空格 str.replace(/^\s*/,""); //去除字符串內左側的空格 str.replace(/(\s*$)/g,""); //去除字符串內右側的空格 }
佔位:
不佔位:
僅對塊內文本元素:
function delLast(str, target) { return str.split('').reverse().join('').replace(target, '').split('').reverse().join(''); } const str = delLast('asdfghhj', 'h') console.log(str) // asdfghj
能夠繼承的經常使用屬性
function transfor (str){ var reg=/-[a-z]/g; return str.replace(reg,function(vc){ return vc.slice(1).toUpperCase(); }) } transfor("get-element-by-id"); //getElementById
_self: 在當前窗口打開頁面 _blank: 在新窗口打開頁面 _top: 在整個框架打開頁面不是很理解(在iframe或者frameset裏用的比較多)
字符轉ascii碼:用charCodeAt()
ascii碼轉字符:用fromCharCode(number)
數組轉字符串: Array.join("-")
字符串轉數組: String.split(",")
function tansfrom(str){ //先把字符串轉爲數組 var charStr=str.split(""); //遍歷數組 for(let i=0;i<charStr.length;i++){ if(charStr[i].charCodeAt()>=65&&charStr[i].charCodeAt()<=90){ charStr[i]=String.fromCharCode(charStr[i].charCodeAt()+32); }else if(charStr[i].charCodeAt()>=97&&charStr[i].charCodeAt()<=122){ charStr[i]=String.fromCharCode(charStr[i].charCodeAt()-32); } } return charStr.join(""); } tansfrom("abA");
BFC 全稱爲 塊格式化上下文。是Web頁面的可視化CSS渲染出的一部分。它是塊級盒佈局出現的區域,也是浮動層元素進行交互的區域。
一個塊格式化上下文由如下之一建立:
特性:
function strCount(str, target) { let count = 0 if (!target) return count while(str.match(target)) { str = str.replace(target, '') count++ } return count } console.log(strCount('abcdef abcdef a', 'abc'));
function substrCount(str, target) { let count = 0; while (str.includes(target)) { const index = str.indexOf(target); count++; str = str.substring(index + target.length); } return count; }
var str="abcdacd"; var target="a"; var childInNums = str.split(target).length - 1;
stroage
localStorage和sessionStorage localStorage保存數據會一直保存沒有過時時間,不會隨瀏覽器發送給服務器。大小5M或更大 sessionStorage僅當前頁面有效一旦關閉就會被釋放。也不會隨瀏覽器發送給服務器。大小5M或更大 localStorage和sessionStorage都繼承於Storage,提供了統一的api來訪問和設置數據。api列表爲: clear 清空存儲中的全部本地存儲數據 getItem 接受一個參數key,獲取對應key的本地存儲 key 接受一個整數索引,返回對應本地存儲中索引的鍵 removeItem 接受一個參數key,刪除對應本地存儲的 keysetItem 接受兩個參數,key和value,若是不存在則添加,存在則更新。
localStorage.setItem('order', 'a109'); console.log(localStorage.key(0)); // order console.log(localStorage.getItem('order')) // a109 localStorage.removeItem('order'); localStorage.clear();// 對象訪問方式一樣有效 localStorage.order = 'b110'; localStorage.order; // b110
postmessage
postMessage()方法容許來自不一樣源的腳本採用異步方式進行有限的通訊,能夠實現跨文本檔、多窗口、 跨域消息傳遞。html5引入的message的API,主要的功能: 1.頁面和其打開的新窗口的數據傳遞 2.多窗口之間消息傳遞 3.頁面與嵌套的iframe消息傳遞 4.上面三個問題的跨域數據傳遞 postMessage(data,origin)方法接受兩個參數 1.data:要傳遞的數據,html5規範中提到該參數能夠是JavaScript的任意基本類型或可複製的對象, 然而並非全部瀏覽器都作到了這點兒,部分瀏覽器只能處理字符串參數,因此咱們在傳遞參數的 時候須要使用JSON.stringify()方法對對象參數序列化,在低版本IE中引用json2.js能夠實現相似效果。 2.origin:字符串參數,指明目標窗口的源,協議+主機+端口號[+URL],URL會被忽略,因此能夠不寫, 這個參數是爲了安全考慮,postMessage()方法只會將message傳遞給指定窗口, 固然若是願意也能夠建參數設置爲"*",這樣能夠傳遞給任意窗口,若是要指定和當前窗口同源的話設置爲"/"。
index.html
<div style="width:200px; float:left; margin-right:200px;border:solid 1px #333;"> <div id="color">Frame Color</div> </div> <div> <iframe id="child" src="https://www.test2.com/test2.html"></iframe> </div> window.onload=function(){//傳輸數據 window.frames[0].postMessage('getcolor','http://lslib.com'); }
test2.html
window.addEventListener('message',function(e){ //接收消息 if(e.source!=window.parent) return; var color=container.style.backgroundColor; window.parent.postMessage(color,'*'); },false);
一開始就針對低版本瀏覽器進行構建頁面,完成基本的功能,而後再針對高級瀏覽器進行效果、
交互、追加功能達到更好的體驗。
一開始就構建站點的完整功能,而後再針對低版本瀏覽器進行兼容。
好比一開始使用 CSS3 的特性構建了一個應用,而後逐步針對各大瀏覽器進行 hack
使其能夠在低版本瀏覽器上正常瀏覽。
若低版本用戶居多,則優先採用漸進加強的開發流程; 若高版本用戶居多,則爲了提升大多數用戶的使用體驗,那固然優先採用優雅降級的開發流程。
typeof 只能判斷基本類型 string,number,boolean,undefined,object
null 會被判斷成 object
比較全面的是使用 Object.prototype.toString 方法,只須要對返回值進行字符串分割便可
const typeCheck = (obj) => { const typeStr = Object.prototype.toString.call(obj); //返回格式:[object xxxxx] return typeStr.toLowerCase().slice(8, typeStr.length - 1); }; console.log(typeCheck("str")); //string console.log(typeCheck(1)); //number console.log(typeCheck(() => null)); //function console.log(typeCheck({a: 1})); //object console.log(typeCheck([1, 2, 3]));//array console.log(typeCheck(new Set([1,2,3]))); //set