import React from 'react';
import Red from './images/red.png'
import Yellow from './images/yellow.png'
import Green from './images/blue.png'
class Warn extends React.Component {
constructor(props) {
super(props);
this.state = {
dataHeader: '',
dataContent: ''
}
this.tableTimer = null;
}
/**
* 動態(tài)創(chuàng)建表格
* @private
*/
_createTable() {
const self = this; // 指向本對象的指針
console.log('=================創(chuàng)建表格開始=================');
console.log(self);
console.log('=================創(chuàng)建表格結(jié)束=================');
var warning = document.getElementsByClassName('warning')[0];
// 開始輪播
self.tableTimer = self._setInterval(self._replaceTable, 5000, this.state.dataContent);
}
/**
* 替換表格內(nèi)容
*/
_replaceTable(content){
const self = this;
console.log('=================replaceTable=================');
console.log(self);
console.log('=================replaceTable=================');
}
/**
* 可帶參數(shù)的定時去
* @param callback
* @param timeout
* @param param
* @private
*/
_setInterval(callback,timeout,param){
const self = this;
console.log(self)
var _sto = setInterval;
// slice() 方法可從已有的數(shù)組中返回選定的元素
// arrayObject.slice(start,end)
var args = Array.prototype.slice.call(arguments,2);
console.log(args)
var _cb = function()
{
callback.apply(null,args);
}
var stoTimer = _sto(_cb,timeout);
return stoTimer;
}
componentDidMount() {
this._createTable();
}
// 組件接收到新的props時調(diào)用,并將其作為參數(shù)nextProps使用
componentWillReceiveProps(nextProps) { // 接收新的參數(shù)
var dataFlowPercentage01 = []
}
componentDidUpdate() {
console.log('表格正式更新')
const self = this;
}
render() {
let self = this;
var divStyle = {
width: 632,
height: 210,
position: 'absolute',
left: 235,
top:120,
color: '#D8D8D8',
fontSize: 50
//backgroundColor: 'yellow'
}
return (
<div className={'warning'} style={divStyle}>
這個
</div>
);
}
}
export default Warn;
下面這段代碼將_setInterval
的回調(diào)函數(shù)的this
都指向了null
。
另外如果只修改下面這段代碼,this
的會指向undefined
。根本原因是回調(diào)函數(shù)運(yùn)行環(huán)境的this并不指向當(dāng)前組件。解決方法是在構(gòu)造函數(shù)中用bind綁定方法,或者使用箭頭函數(shù)
var _cb = function()
{
callback.apply(null,args);
}
//1.bind綁定
constructor() {
// ...
this.method = this.method.bind(this)
}
//2.箭頭函數(shù)
class XXX extend Component {
constructor() {}
method = () => {
// ...
}
}
// 將你的_createTable方法重寫如下編寫
_createTable(){
const self = this; // 指向本對象的指針
console.log('=================創(chuàng)建表格開始=================');
console.log(self);
console.log('=================創(chuàng)建表格結(jié)束=================');
var warning = document.getElementsByClassName('warning')[0];
// 開始輪播 //TODO 這里代碼重構(gòu)
//self.tableTimer = self._setInterval(self._replaceTable, 5000, this.state.dataContent);
self.tableTimer = self._setInterval(()=>{
self._replaceTable();
},5000,this.state.dataContent)
}
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學(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),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jī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ù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。