Follow

Keep Up to Date with the Most Important News

By pressing the Subscribe button, you confirm that you have read and are agreeing to our Privacy Policy and Terms of Use
Contact

Element created with document.createElement inside an if Condition not recognized outside

I have been trying to use createElement inside an if statement but it just doesn’t work. The headerLink is not recognized outside of the if statement.

Can someone explain what’s missing?

What I have tried so far:

MEDevel.com: Open-source for Healthcare and Education

Collecting and validating open-source software for healthcare, education, enterprise, development, medical imaging, medical records, and digital pathology.

Visit Medevel

  1. Declaring headerLink outside the if statement. This doesn’t work

  2. If I move the appendChild and removeChild inside the if statement, it starts to work. But, that would result in duplicate code since I will need to copy the same inside the else statement

    React.useEffect(() => {
        const head = document.head;
        const scriptType = "text/css";
    
    
        if (scriptType === "text/css") {
            const headerLink = document.createElement( "link" );
        } else {
            const headerLink = document.createElement( "script" ); 
        }
    
    
        // this line doesn't work - headerLink is not recognized
        head.appendChild(headerLink);
    
        return () => {  
            // this line doesn't work - again, headerLink is not recognized
            head.removeChild(headerLink);
        };
    }, []);
    

>Solution :

You can move the declaration of the headerLink outside the if clause. But you will have to use let in that case.

let headerLink;

if (scriptType === "text/css") {
    headerLink = document.createElement( "link" );
} else {
    headerLink = document.createElement( "script" ); 
}

Or you can use ternary conditional operator to create element

const headerLink = document.createElement( scriptType === "text/css" ? "link" : "script" );
Add a comment

Leave a Reply

Keep Up to Date with the Most Important News

By pressing the Subscribe button, you confirm that you have read and are agreeing to our Privacy Policy and Terms of Use

Discover more from Dev solutions

Subscribe now to keep reading and get access to the full archive.

Continue reading