Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
369 views
in Technique[技术] by (71.8m points)

reactjs - props not working inside normal javascript function .Cannot read property 'props' of undefined

Here is my code.

var i = 0;

function myLoop() {
    let xhr1 = new XMLHttpRequest();
    xhr1.open('GET', data.data[0].sideList[i].sideSvg);
    xhr1.onload = () => {
        document.getElementById("configurator_side_" + i)
            .appendChild(xhr1.responseXML.documentElement);
        i++;
        this.props.dispatch(storeActions.setSideThumbSvg());
        if (i < data.data[0].sideList.length) {
            myLoop();
        }
    };
    xhr1.send();
}

myLoop();

I think "this" keyword is not accessible inside normal javascript. Please suggest .

question from:https://stackoverflow.com/questions/65852579/props-not-working-inside-normal-javascript-function-cannot-read-property-props

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Reply

0 votes
by (71.8m points)

In your constructor bind that function to your current class , as below :

constructor( props ){
    super( props );
    this.myLoop = this.myLoop.bind(this);
}

function myLoop() {

    // self = this;
    let xhr1 = new XMLHttpRequest();
    xhr1.open('GET', data.data[0].sideList[i].sideSvg);
    xhr1.onload = () => {
        document.getElementById("configurator_side_" + i)
            .appendChild(xhr1.responseXML.documentElement);
        i++;
        this.props.dispatch(storeActions.setSideThumbSvg());
        if (i < data.data[0].sideList.length) {
            myLoop();
        }
    };
    xhr1.send();
}

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
OGeek|极客中国-欢迎来到极客的世界,一个免费开放的程序员编程交流平台!开放,进步,分享!让技术改变生活,让极客改变未来! Welcome to OGeek Q&A Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

...