umi中history和useModel的使用

1.history:

history 是用于在 React 组件中进行页面导航和管理历史记录的工具。通过 history,你可以在不同页面之间进行跳转、监听路由变化等操作。在 Umi 中,通常会使用 history 对象来实现页面的跳转和路由相关的操作。示例代码可能如下所示:

发:
import { history } from '@umijs/max';
// 在某个事件触发时跳转到指定页面,并传递参数
const handleClick = () => {
  const params = {
    id: 123,
    name: 'example',
  };
  history.push({
    pathname: '/another-page',
    query: params,
  });
};

收:
import { useLocation } from 'umi';
const AnotherPage = () => {
  const location = useLocation();
  const params = location.query;
  console.log(params); // { id: 123, name: 'example' }
  return (
    <div>
      <h1>Another Page</h1>
      <p>ID: {params.id}</p>
      <p>Name: {params.name}</p>
    </div>
  );
};

很少使用字符串拼接的传递参数:

发:
import { history } from '@umijs/max';
// 在某个事件触发时跳转到指定页面,并传递参数
const handleClick = () => {
  const id = 123;
  history.push(`/another-page/${id}`);
};

收:
import { useParams } from 'umi';
const AnotherPage = () => {
  const params = useParams();
  console.log(params.id); // 123
  return (
    <div>
      <h1>Another Page</h1>
      <p>ID: {params.id}</p>
    </div>
  );
};

2.useModel:

useModel 是一个用于在函数式组件中获取和操作 Umi Model 的钩子函数。在 Umi 中,Model 是一种用于管理数据和状态的概念,可以帮助你更好地组织和管理应用程序的数据流。通过 useModel,你可以在函数式组件中轻松地访问和操作 Model 中的数据和方法。示例代码可能如下所示:

import { useModel } from '@umijs/max';

const MyComponent = () => {
  const { data, loading, error, fetchList } = useModel('example');

  useEffect(() => {
    // 在组件加载时获取数据
    fetchList();
  }, []);

  if (loading) {
    return <div>Loading...</div>;
  }

  if (error) {
    return <div>Error: {error.message}</div>;
  }

  return (
    <div>
      <h1>Example Data:</h1>
      <ul>
        {data.map(item => (
          <li key={item.id}>{item.name}</li>
        ))}
      </ul>
    </div>
  );
};

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
umi 是一个基于 React 的企业级前端应用开发框架,可以帮助开发者快速构建高质量的单页应用或多页应用。使用 umi 时,可以通过 useModel使用 umi 的模型。 useModelumi 用于访问和管理模型的 Hook,可以在函数组件使用。在使用 useModel 之前,需要先在 model 文件夹定义模型。 具体使用方法如下: 1. 在函数组件引入 useModel ``` import { useModel } from 'umi'; ``` 2. 使用 useModel 获取模型对象 ``` const model = useModel('modelName'); ``` 其modelName 是在 model 文件夹定义的模型名称。 3. 在组件使用模型 ``` function MyComponent() { const model = useModel('modelName'); const { data, error, loading } = model.someEffect(); // ... } ``` 在组件,可以通过模型对象调用模型的方法,例如一些异步操作。 注意:在使用 useModel 之前,需要先在 config/config.ts 文件配置 model 属性,指定 model 文件夹的路径。 ``` export default { // ... // 配置 model 文件夹的路径 // 即 model 文件夹所在的目录 // 默认为 src/models // 如果在根目录下创建了 models 目录,则需要手动指定路径为 ./models // 如果没有使用 model,则可以省略该属性 // 例如:model: {}, model: { // 指定 model 文件夹的路径 // 如果 models 目录在根目录下,则为 './models' // 如果 models 目录在 src 目录下,则为 './src/models' // 如果没有使用 model,则可以省略该属性 // 例如:'./models', dir: 'model', }, // ... }; ``` 以上就是使用 umi useModel Hook 的基本方法,希望能帮助到你。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

每天吃饭的羊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值