[react]不能将类型“string | undefined”分配给类型“To”。 不能将类型“undefined”分配给类型“To”

场景, 封装组件的时候, 想通过外部传进去一个路由地址, 再用<Link to={}>跳转, 显示这个,

有四种方法解决

第一种 合并运算符 ??

??空值合并运算符 (Nullish Coalescing Operator),它是 JavaScript 和 TypeScript 中的一种逻辑运算符,通常用于处理 nullundefined 的情况。

javascript 复制代码
a ?? b

解释:

  • 如果 a 不是 nullundefined ,那么 a ?? b 会返回 a 的值。
  • 如果 anullundefined,那么 a ?? b 会返回 b 的值。
javascript 复制代码
             <div className="right">
                {/* 第一种 */}
                <Link to={props.moreTextHref ?? ''}>{props.moreText}</Link>           
            </div>

第二种

使用条件渲染

javascript 复制代码
  {
        props.moreTextHref && (
              <Link to={props.moreTextHref}>{props.moreText}</Link>
       )}

第三种

类型断言来明确告诉 TypeScript props.moreTextHref 不会是 undefined

javascript 复制代码
  <Link to={props.moreTextHref as string}>{props.moreText}</Link>

第四种

强制传递的就是字符串

javascript 复制代码
interface IProps {
    children?: ReactNode;
    title?: string;
    keywords?: string[];
    moreText?: string;
    // 把问号去掉
    moreTextHref: string;
}
相关推荐
xuco6 分钟前
如何让流式输出的 Markdown 渲染更丝滑
前端·agent
Pu_Nine_96 分钟前
Vue3 + ECharts 企业级封装实践:按需引入 + useECharts Hooks
前端·vue.js·echarts
问心无愧05137 分钟前
ctf show web入门91
android·前端·笔记
YAwu119 分钟前
JavaScript 作用域与执行机制深度解析
前端·javascript
暗不需求10 分钟前
深入理解 React 受控组件与非受控组件:从源码到面试
前端·react.js·面试
Yue16810 分钟前
天津理工大学前端组大一末期考核随记(2)
前端·javascript
冰凌时空10 分钟前
Swift 类型系统入门:从 Int、String 到自定义类型
前端·ios·ai编程
hexu_blog14 分钟前
前端vue后端java+springboot如何实现pdf,word,excel之间的相互转换
java·前端·vue.js·spring boot·文档转换
w_t_y_y44 分钟前
vue父子组件通信(二)祖先调用inject
前端·javascript·vue.js
哆哆啦001 小时前
URL 重写规则和静态资源解析逻辑
前端·浏览器·url