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)建表格結束=================');
var warning = document.getElementsByClassName('warning')[0];
// 開始輪播
self.tableTimer = self._setInterval(self._replaceTable, 5000, this.state.dataContent);
}
/**
* 替換表格內容
*/
_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時調用,并將其作為參數(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的回調函數(shù)的this都指向了null。
另外如果只修改下面這段代碼,this的會指向undefined。根本原因是回調函數(shù)運行環(huán)境的this并不指向當前組件。解決方法是在構造函數(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)建表格結束=================');
var warning = document.getElementsByClassName('warning')[0];
// 開始輪播 //TODO 這里代碼重構
//self.tableTimer = self._setInterval(self._replaceTable, 5000, this.state.dataContent);
self.tableTimer = self._setInterval(()=>{
self._replaceTable();
},5000,this.state.dataContent)
}北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達內教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學校辦產(chǎn)業(yè)為響應國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復興的升級產(chǎn)業(yè)鏈。利用北京大學優(yōu)質教育資源及背
博為峰,中國職業(yè)人才培訓領域的先行者
曾工作于聯(lián)想擔任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經(jīng)理職務負責iOS教學及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術, 熟練的跨平臺面向對象開發(fā)經(jīng)驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術顧問,美國Dachieve 系統(tǒng)架構師,美國AngelEngineers Inc. 系統(tǒng)架構師。