摘要:作者陳大魚頭如果不希望職業(yè)生涯過早結(jié)束,持續(xù)學(xué)習(xí)對于開發(fā)者來說是必不可少的。最近前端面試之道的作者為了讓一些人能在這塊地方記錄自己學(xué)習(xí)到的內(nèi)容而建立起了一個學(xué)習(xí)倉庫。例子如下我們首先定義一個文件叫,一個文件叫。
作者:陳大魚頭
github: KRISACHAN
如果不希望職業(yè)生涯過早結(jié)束,持續(xù)學(xué)習(xí)對于開發(fā)者來說是必不可少的。
最近《前端面試之道》的作者為了讓一些人能在這塊地方記錄自己學(xué)習(xí)到的內(nèi)容而建立起了一個學(xué)習(xí)倉庫。
倉庫地址如下:
https://github.com/KieSun/tod...
這些內(nèi)容通常會是一個小點,可能并不足以寫成一篇文章。但是這個知識點可能很多人也不知道,那么通過這種記錄的方式讓別人同樣也學(xué)習(xí)到這個知識點就是一個很棒的事情了。
具體的知識點如下:
CSS CSS Houdini我們在日常開發(fā)中可能會用到過許多 CSS IN JS 或者 CSS module 的方案,但是 JS IN CSS ,你聽說過嗎?
CSS Houdini 是由一群來自各個國際大廠的工程師所組成的工作小組,志在建立一系列的 API來讓開發(fā)者能夠介入瀏覽器的CSS引擎中,用來解決 CSS 長久以來的問題。
例子如下:
我們首先定義一個JS文件叫houdini.js,一個HTML文件叫index.html。
houdini.js 文件內(nèi)容如下:
"use strict" registerPaint("overdraw", class { static get inputProperties() { return ["--border-width"]; } paint(ctx, geom, properties) { const borderWidth = parseInt(properties.get("--border-width")); ctx.shadowColor = "rgba(0,0,0,0.25)"; ctx.shadowBlur = borderWidth; ctx.fillStyle = "rgba(255, 255, 255, 1)"; ctx.fillRect(borderWidth, borderWidth, geom.width - 2 * borderWidth, geom.height - 2 * borderWidth); } });
index.html 文件內(nèi)容如下:
demo
然后開個靜態(tài)服務(wù)器,就可以看效果了,效果如下:
JS 另類的數(shù)組求和let arr = [1, 2, 3, 4, 5] eval(arr.join("+"))數(shù)組完全展開
function myFlat(arr) { while (arr.some(t => Array.isArray(t))) { arr = ([]).concat.apply([], arr); } return arr; } var arrTest1 = [1, [2, 3, [4]], 5, 6, [7, 8], [[9, [10, 11], 12], 13], 14]; // Expected Output: [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14] console.log(myFlat(arrTest1))實現(xiàn) sleep 函數(shù)
function sleep(interval) { return new Promise(resolve => { setTimeout(resolve, interval); }) } async function test() { for (let index = 0; index < 10; index++) { console.log(index); await sleep(2000) } }正則過濾違規(guī)詞
var ma = "大傻逼".split(""); var regstr = ma.join("([^u4e00-u9fa5]*?)"); var str = "這是一篇文章,需要過濾掉大燒餅這三個詞,大燒餅中間出漢字以外的字符 大_/_燒a1v餅和 大燒a1v餅"; var reg = new RegExp(regstr , "g"); str.replace(reg,"<替換的詞>");Node 開啟 Gzip
const express = require("express"); const compression = require("compression"); const app = express(); app.use(compression());統(tǒng)計 Git 代碼行數(shù)
const { exec } = require("child_process"); const { argv } = require("yargs"); const readLines = stdout => { const stringArray = stdout .toString() .split(/( )/g) .filter(str => str !== " " && str); const dataArray = []; stringArray.map(str => { const data = str.split(/( )/g).filter(str => str !== " "); const [newLine, deletedLine, filePath] = data; dataArray.push({ newLine, deletedLine, filePath }); }); return dataArray; }; try { if (!argv.commit) throw new Error("") exec(`git diff ${argv.commit} --numstat`, (error, stdout, stderr) => { console.table(readLines(stdout)); }); } catch (e) { console.log(e); }實現(xiàn)一個only函數(shù)
var obj = { name: "tobi", last: "holowaychuk", email: "[email protected]", _id: "12345" }; const only = (obj, para) => { if (!obj || !para) { new Error("please check your args!") } let newObj = {}; let newArr = Array.isArray(para) ? para : typeof (para) === "string" ? para.split(/ +/) : []; newArr.forEach((item) => { if (item && obj[item] && !newObj[item]) { newObj[item] = obj[item]; } }) return newObj; } // {email: "[email protected]", last: "holowaychuk", name: "tobi"} console.log(only(obj, ["name", "last", "email"])); console.log(only(obj, "name last email"));實際業(yè)務(wù)問題 視頻兼容相關(guān)
在安卓中,直接使用原生 video 會導(dǎo)致全屏播放,蓋住所有元素,因此使用 x5 播放器。但是 x5 播放器還是存在問題,雖然不會蓋住元素,但是會自己添加特效(蓋一層導(dǎo)航欄蒙層)。
這樣可以在安卓下使用 x5 播放器, playsInline 及 webkit-playsinline 屬性可以在 iOS 環(huán)境下啟用內(nèi)聯(lián)播放。但是通過屬性設(shè)置內(nèi)聯(lián)播放兼容性并不怎么好,所以這時候我們需要使用 iphone-inline-video[2] 這個庫,通過 enableInlineVideo(video) 就可以了。
聊天數(shù)據(jù)渲染考慮到直播中聊天數(shù)據(jù)頻繁,因此所有接收到的數(shù)據(jù)會先存入一個數(shù)組 buffer 中,等待 2 秒后統(tǒng)一渲染。
// 接收到消息就先 push 到緩存數(shù)組中 this.bufferAllComments.push({ customerName: fromCustomerName, commentId, content, commentType }) // 利用定時器,每兩秒將數(shù)組中的中的 concat 到當(dāng)前聊天數(shù)據(jù)中并清空緩存 this.commentTimer = setInterval(() => { if (this.bufferAllComments.length) { this.appendChatData(this.bufferAllComments) this.bufferAllComments = [] } }, 2000)鏈表作為聊天數(shù)據(jù)的載體
同樣考慮到直播中聊天數(shù)據(jù)頻繁插入,因此使用鏈表來存儲顯示的聊天數(shù)據(jù),目前只存儲 50 條數(shù)據(jù),這樣刪除前面的只要很簡單。
使用鏈表的原因是考慮到頻繁的去除數(shù)組頭部數(shù)據(jù)去造成空間復(fù)雜度的問題
另外也實現(xiàn)了支持迭代器的功能,代碼如下:
[Symbol.iterator] () { let current = null; let target = this return { next () { current = current != null ? current.next : target.head if (current != null) { return { value: current.value, done: false } } return { value: undefined, done: true } }, return () { return { done: true } } } }總結(jié) 工作中建立起來的一些心得
要根據(jù)任務(wù)四象限劃分好每天要做的事,按緊急度去完成任務(wù)(重要緊急,重要不緊急,緊急不重要,不重要不緊急);
學(xué)會自我總結(jié)(寫周報或日志匯總所遇到的問題,時刻翻閱);
擁有快速定位并解決問題的能力(通過已知的條件去判斷所遇到的問題);
要多與上下游溝通,了解團(tuán)隊大家所做的事以及進(jìn)度(方便自己合理安排任務(wù));
積極樂觀不抱怨(最好可以時常給團(tuán)隊帶來正能量,而不是滿腹抱怨);
多運動,多休息(身體革命的本錢,沒有一個好的身體就什么都做不了)。
最后這是一個需要大家一起分享才能持續(xù)下去的事情,光靠我,YCK或者少量幾個人分享是做不下去的。歡迎大家參與到這件事情中來,地址如下:
https://github.com/KieSun/tod...
如果你、喜歡探討技術(shù),或者對本文有任何的意見或建議,你可以掃描下方二維碼,關(guān)注微信公眾號“魚頭的Web海洋”,隨時與魚頭互動。歡迎!衷心希望可以遇見你。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/105937.html
摘要:作者陳大魚頭如果不希望職業(yè)生涯過早結(jié)束,持續(xù)學(xué)習(xí)對于開發(fā)者來說是必不可少的。最近前端面試之道的作者為了讓一些人能在這塊地方記錄自己學(xué)習(xí)到的內(nèi)容而建立起了一個學(xué)習(xí)倉庫。例子如下我們首先定義一個文件叫,一個文件叫。 作者:陳大魚頭 github: KRISACHAN 如果不希望職業(yè)生涯過早結(jié)束,持續(xù)學(xué)習(xí)對于開發(fā)者來說是必不可少的。 最近《前端面試之道》的作者為了讓一些人能在這塊地方記...
摘要:其中經(jīng)歷了入門到放棄系列的火熱,想起了此題目,可直到其熱度褪去依然沒有開寫。再之前的實習(xí)也是上午面試下午入職的。 這是前幾篇前端面試文章的結(jié)尾,是很多個月前就該寫下的事情。其中經(jīng)歷了入門到放棄系列的火熱,想起了此題目,可直到其熱度褪去依然沒有開寫。不能再拖了,否則事情估計都快忘光了。 面試過程 依然是某金融集團(tuán)的外包,這次換了一個外包公司。首先是電話面試,還是還是些常見的前端問題,自己...
摘要:首先一上來就分享了兩個學(xué)習(xí)方法建立知識架構(gòu)追本溯源。列一份前端知識架構(gòu)圖在這章節(jié)中,分享了本專欄要學(xué)習(xí)的知識架構(gòu)瀏覽器的實現(xiàn)原理和前端工程實踐四個模塊。最后一個是前端工程實踐,從性能工具鏈持續(xù)集成搭建系統(tǒng)架構(gòu)與基礎(chǔ)庫五個方面講起。 明確你的前端學(xué)習(xí)路線 自己特別喜歡屯課,看著自己買的課,有種滿足感,仿佛知識都是我的了,翻看極客時間買的課,決定這段時間把重學(xué)前端專欄學(xué)習(xí)一遍。 從周六到今...
摘要:好好打基礎(chǔ),然后多嘗試不同風(fēng)格的框架,因為只有嘗試過后才能理解比如徐飛提到的各種權(quán)衡,也只有嘗試過后才能知道哪個能真正提升自己的開發(fā)效率。 今天看了幾篇關(guān)于這三個主流框架的PK,如標(biāo)題:react.js,angular.js,vue.js學(xué)習(xí)哪個好?相信每個人都有這種問題。 現(xiàn)在的前端框架層出不窮,作為前端開發(fā)者何去何從?fackbook的react.js盛世火熱,react nati...
摘要:看起來沒有集合框架,線程,等那么耀眼,但它可是很多框架的基礎(chǔ)啊回復(fù)反射查看相關(guān)文章,先把基礎(chǔ)學(xué)會,后面的得用到它。 回頭看看, 我進(jìn)入Java 領(lǐng)域已經(jīng)快15個年頭了, 雖然學(xué)的也一般, 但是分享下我的心得,估計也能幫大家少走點彎路。[入門]我在2001年之前是C/C++陣營, 有C和面向?qū)ο蟮幕A(chǔ), 后來轉(zhuǎn)到Java ,發(fā)現(xiàn)沒有指針的Java真是好簡單, 另外Java 的類庫好用的讓...
閱讀 1371·2021-09-02 10:19
閱讀 1110·2019-08-26 13:25
閱讀 2118·2019-08-26 11:37
閱讀 2427·2019-08-26 10:18
閱讀 2684·2019-08-23 16:43
閱讀 3020·2019-08-23 16:25
閱讀 787·2019-08-23 15:53
閱讀 3307·2019-08-23 15:11