JS 部分:
function removeTransition(e) {
if (e.propertyName !== 'transform') return;
e.target.classList.remove('playing');
}
keys.forEach(key => key.addEventListener('transitionend', removeTransition));
css 部分:
.key {
transition: all .07s ease;
}
.playing {
box-shadow: 0 0 1rem #ffc600;
transform: scale(1.1);
border-color: #ffc600;
}
其余還有部分代碼,主要是監(jiān)聽鍵盤上的keydown
事件,當(dāng)某個(gè)key
被按下后,執(zhí)行:
key.classList.add('playing');
我不清除的是,removeTransition
在什么時(shí)候被調(diào)用?以及 .remove('playing')
之后,新的樣式在什么時(shí)候渲染?
查到瀏覽器在處理 css 的時(shí)候,會(huì)先終止 JS 的執(zhí)行。那 transitioned
事件在什么時(shí)候被觸發(fā)?
transitionend
事件會(huì)在 CSS transition 結(jié)束后觸發(fā)。
在你的例子中,transitionend
確實(shí)會(huì)多次觸發(fā)。
比如
transition: width 2s, height 2s, background-color 2s, transform 2s;
那么 transitionend
事件會(huì)被觸發(fā) 4 次。
如果在中途取消了過渡動(dòng)畫,那么 transitionend
就不會(huì)觸發(fā)?;蛘?transition 完成前設(shè)置 display
為 "none"
,事件同樣不會(huì)被觸發(fā)。
transition后加過渡時(shí)間,transitionend 事件會(huì)在時(shí)間間隔后才會(huì)被觸發(fā)。所以我的理解是css先加載,但是這個(gè)過渡的過程是異步的,此時(shí)綁定transitionend 事件的腳本已經(jīng)執(zhí)行到了。不知道我這樣理解對(duì)不對(duì),如果不對(duì)還望有人指正。
我做了一個(gè)實(shí)驗(yàn):
html:
<div class="transition_div" id="transition_div" onmouseover="fun_hover()">
</div>
js:
function fun_transitionend(){
console.log("transition end");
}
function fun_hover(){
console.log("start event binding");
document.getElementById("transition_div").addEventListener('transitionend',fun_transitionend);
}
css:
.transition_div{
height:100px;
width:100px;
background:red;
-webkit-transition:width 5s;
-moz-transition:width 5s;
-ms-transition:width 5s;
-o-transition:width 5s;
transition:width 5s;
}
.transition_div:hover
{
width:300px;
}
圖形開始過渡變換寬度的時(shí)候,事件綁定代碼開始執(zhí)行,變換完成后觸發(fā)transitionend事件處理函數(shù)。
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國(guó)IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國(guó)家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國(guó)一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國(guó)成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫(kù),具有快速界面開發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國(guó)Software AG 技術(shù)顧問,美國(guó)Dachieve 系統(tǒng)架構(gòu)師,美國(guó)AngelEngineers Inc. 系統(tǒng)架構(gòu)師。