最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

javascript - ReactDom createPortal() doesn't work but render() does, and only once not if trigger is repeated - why is t

programmeradmin3浏览0评论

Newbie to react here.

TLDR: I have a helper function called createNotification which when called inserts a <ToastNotification /> ponent into a container element using render(). If I use createPortal() nothing is appended. If I use render, the ponent is only added once despite multiple triggers.

Can anyone help me figure out whats happening please?

Thank you

helpers.js


import { ToastNotification } from "carbon-ponents-react";
import { render, createPortal } from "react-dom";

export const createNotification = () => {
  const container = document.getElementById("notificationContainer");
  console.log(container); //just to check function is running and has found container
  return render(<ToastNotification />, container); //works but only once, not on multiple triggers
  return createPortal(<ToastNotification />, container); //doesn't render anything in container
};

the function above is called from other ponents as needed:

login.js

import { createNotification } from "../../helpers";

const Login = () => {
  const validateLogin = async (event) => {
    createNotification();
    // validation logic
    performLogin();
  };

  const performLogin = async () => {
    //axios call here
  };

  // main ponent content
  return (
    <>
     <!-- validateLogin() called on form submit -->
    </>
  );
};

export default Login;

app.js

//imports

function App() {
  return (
    <div>
      <div className="App"></div>
    </div>
  );
}
export default App;


Thank you

Newbie to react here.

TLDR: I have a helper function called createNotification which when called inserts a <ToastNotification /> ponent into a container element using render(). If I use createPortal() nothing is appended. If I use render, the ponent is only added once despite multiple triggers.

Can anyone help me figure out whats happening please?

Thank you

helpers.js


import { ToastNotification } from "carbon-ponents-react";
import { render, createPortal } from "react-dom";

export const createNotification = () => {
  const container = document.getElementById("notificationContainer");
  console.log(container); //just to check function is running and has found container
  return render(<ToastNotification />, container); //works but only once, not on multiple triggers
  return createPortal(<ToastNotification />, container); //doesn't render anything in container
};

the function above is called from other ponents as needed:

login.js

import { createNotification } from "../../helpers";

const Login = () => {
  const validateLogin = async (event) => {
    createNotification();
    // validation logic
    performLogin();
  };

  const performLogin = async () => {
    //axios call here
  };

  // main ponent content
  return (
    <>
     <!-- validateLogin() called on form submit -->
    </>
  );
};

export default Login;

app.js

//imports

function App() {
  return (
    <div>
      <div className="App"></div>
    </div>
  );
}
export default App;


Thank you

Share Improve this question edited Nov 28, 2021 at 12:53 rugy asked Nov 28, 2021 at 11:55 rugyrugy 2561 gold badge3 silver badges13 bronze badges 2
  • did you render createNotification or whole app by render funtion ? – Robert Commented Nov 28, 2021 at 12:03
  • app.js was return() and createNotification() is called in the Login() ponent (code added above) – rugy Commented Nov 28, 2021 at 12:51
Add a ment  | 

2 Answers 2

Reset to default 6

Solved this myself by adding the createPortal() within the render().

If anyone can provide an explanation, it would be much appreciated.

export const createNotification = () => {
  const container = document.getElementById("notificationContainer");
  console.log(container);
  return render(createPortal(<ToastNotification />, container), document.createElement("div"));
};

createNotification aren't mounted in ponent in app Virtual Dom... when you use render(createPortal) then you just create spearted app.

import { createNotification } from "../../helpers";

export const createNotification = () => {
    const container = document.getElementById("notificationContainer");
    console.log(container); //just to check function is running and has found container
    return createPortal(<ToastNotification />, container); //doesn't render anything in container
};

const Login = () => {
    const [validate, setValidate] = useState(false);
    
    const validateLogin = async (event) => {
        if('some logic')
            return setValidte(true)
        setVAlidte(false)
    };


    useEffect(() => {
        if(!valite)
            return;
        //axios heare
    }, [validate])
    // main ponent content
    
    
    return (
        <>
            {!validate && <CreateNotfication/>}
            <!-- validateLogin() called on form submit -->
        </>
    );
};

与本文相关的文章

发布评论

评论列表(0)

  1. 暂无评论