zoukankan      html  css  js  c++  java
  • 前端遇到问题

    两个对象相同key会被覆盖

    sendObj={...sendObj, ...sendObj_zh[group]};

    sendObj_zh[group]

    sendObj={...sendObj, group:sendObj_zh[group]};  //应该是因为同一个key 所以后面的header把前面的替换了

    js 对象的key为变量 加上[]

    module/hero.js

    export default {
      namespace: 'hero', // 默认与文件名相同
      state: {heros:[],},
      subscriptions: {
        setup({ dispatch, history }) {
            return history.listen(({ pathname, query }) => {
                if (pathname === '/hero') {
                    dispatch({
                        type: 'fetch'
                    })
                }
            });
        }
    },
    reducers: {
      save(state, action) {
        return { ...state, ...action.payload };
      },
    },
      effects: {
        *fetch({ type, payload }, { put, call, select }) {
          const data = [
            {
              ename: 105,
              cname: '廉颇',
              title: '正义爆轰',
              new_type: 0,
              hero_type: 3,
              skin_name: '正义爆轰|地狱岩魂',
            },
            {
              ename: 106,
              cname: '小乔',
              title: '恋之微风',
              new_type: 0,
              hero_type: 2,
              skin_name: '恋之微风|万圣前夜|天鹅之梦|纯白花嫁|缤纷独角兽',
            },
          ];
          yield put({
            type: 'save',
            payload: {
              heros: data,
            },
          });
        },
      },
    }

    pages/hero.js

    import styles from './hero.css';
    import { connect } from 'dva';
    
    function Hero(props) {
      console.log(props.hero);
      return (
        <div className={styles.normal}>
          <h1>Page hero</h1>
          <h2>This is {JSON.stringify(props.hero)}</h2>
        </div>
      );
    }
    export default connect(({ hero }) => ({ hero }))(Hero);

    const handleSubmit = (e: any) => {
        e.preventDefault();
        const {dispatch}=props;
        loading=true;***********
        props.form.validateFieldsAndScroll((err: any, values: any) => {
          if (!err) {
            dispatch({
              type:'contact/send',
              payload: {
                ...values
              }
            });
            console.log('Received values of form: ', values);
          }
        });
      };

    在项目中我想改变把redux取下的变量的值,但是有函数作用域,必须用hook 或者class component 生命周期函数

    react hook

    顺序

    hook

    取值

    构造

    function

    {eType}    等价于   eType: eType

    antd:

    getFieldValue只能取静态的值

    form中 正则表达式不要引号

    type: 'string',//不要用number 这是垃圾
    { len: isPaymentType? 6 : null,},//两个检查可以有两个括号
    { validator: isPaymentType ? checkBid : null }//validator是独立的,不依赖其他rules执行
    <div className={styles.optionalLabel}>
              <Form.Item label={
                <Title />
              }
                hasFeedback
                validateStatus={validatingType}
              >
                {getFieldDecorator('businessId', {
                  rules: [
                    {
                      required: isPaymentType, 
                      type: 'string',//不要用number 这是垃圾
                      pattern: /^[0-9]*$/,
                    },
                    { len: isPaymentType? 6 : null,},//两个检查可以有两个括号
                    { validator: isPaymentType ? checkBid : null }//validator是独立的,不依赖其他rules执行
                  ],
                })(<Input placeholder={tx('t_Enter 6-digit BusinessID(optional)')} />)}
              </Form.Item>
            </div>

     直接可以调用reduce 通过dispatch直接改变redux中的值 但是又不和后端交互

    } else if (validatingType === 'success') {
          dispatch({
            type: 'contact/setValidateResult',
            validateResult: false,
          });

    javascript调用函数加不加括号的区别

    https://blog.csdn.net/czh500/article/details/101953095

    先要maptoProps 才能在props里取到

    service 娶不到 mock 中的req.body

    body从data中取 这是umi-request的要求

    reducer取值:

    step,email

    前一个不对,一个reducer只能有一个操作。

    effects:{
        *sendResetPasswordRequest(email,{call, put}){
          const response=yield call(postEmail,email);
          if (response.success) {
            yield put({
              type: 'setPasswordStep',
              resetPasswordStep: 2,
            });
            yield put({
              type: 'saveEmail',
              email:response.result.email
            });
            message.success(response.message);
          }
          if(response.error) {
            message.error(response.message);
          }
        }
      },
      reducers:{
        setPasswordStep(state = forgetSettings, { resetPasswordStep }, ) {
          return {
            ...state,
            resetPasswordStep,
          };
        },
        saveEmail(state = forgetSettings, { email }, ) {
          return {
            ...state,
            email
          };
        },
      },

    从后台取出先save到redux 所以是save

    如何取后台数据及制造后台数据

    后台数据 拆分 一般是做成数组形式 然后map

    const customersteps = [
      {
        t_SetUpYourProfile: [
          { t_CreateFirstMenuListing: false },
          { t_UploadPDFMenu: false },
          { t_ViewYourProfile: true },
          { t_UploadBusinessImage: true },
          { t_DownloadQRCode: false },
        ],
      },
      {
        t_CreateDishPool: [{ a: false }],
      },
    ];

    customersteps.map((item)=>{console.log(item)})

    const aaa = {
        t_SetUpYourProfile: [
          { t_CreateFirstMenuListing: false },
          { t_UploadPDFMenu: false },
          { t_ViewYourProfile: true },
          { t_UploadBusinessImage: true },
          { t_DownloadQRCode: false },
        ],
      }

    Object.keys(aaa):
    ["t_SetUpYourProfile"]

    Object.keys(aaa)[0]
    "t_SetUpYourProfile"

    aaa['t_SetUpYourProfile'] aaa是一个对象,所以取对象的value两种写法都可以
    (5) [{…}, {…}, {…}, {…}, {…}]

    aaa.t_SetUpYourProfile
    (5) [{…}, {…}, {…}, {…}, {…}]

    有时候只能用这种取对象value 估计是因为label是字符串的原因

    <SlidebarLists item={item} label={label} firstFalseLabel={firstFalseLabel} />

    读取localStorage 

    setEditingLang(state = odSettings, { editingLang }) {
          localStorage.setItem('popsup-edit-lang', editingLang);
          return {
            ...state,
            editingLang,
          };
    
    
    
    
    export const readUserInfoFromStorage = () => {
      let userInfo: any = false;
      if (localStorage && localStorage.getItem('popsup-authorized-user-info')) {
        userInfo = JSON.parse(localStorage.getItem('popsup-authorized-user-info') as string);
      } //先从localStorage里面读
    
      if (!userInfo) {
        //再从sessionStorage里面读
        if (sessionStorage && sessionStorage.getItem('popsup-authorized-user-info')) {
          userInfo = JSON.parse(sessionStorage.getItem('popsup-authorized-user-info') as string);
        }
      }
      return userInfo;
    };
    
    export const removeUserInfoFromStorage = () => {
      if (localStorage && localStorage.getItem('popsup-authorized-user-info')) {
        localStorage.removeItem('popsup-authorized-user-info');
      }
      if (sessionStorage && sessionStorage.getItem('popsup-authorized-user-info')) {
        sessionStorage.removeItem('popsup-authorized-user-info');
      }
    };

    props里取不到值:

    1.yarn start:no-mock

    2.异步 在渲染之前没取到  用loading解决

    const mockContent = (
        <div>
          {tags.map((tag: any, key: any) =>
            (key >= 3 ? <Tag>{tag}</Tag> : null))
            }
          </div>
      );

    正确

    const mockContent = ()=>(
        <div>
          {tags.map((tag: any, key: any) =>
            (key >= 3 ? <Tag>{tag}</Tag> : null))
            }
          </div>
        )};

    错误

    既然是mockContent 不是 <mockContent />

    ref:

    https://www.shuzhiduo.com/A/ZOJPPWNEJv/

    https://blog.csdn.net/qq_24724109/article/details/103817607

    详细:

    https://blog.csdn.net/weixin_43902189/article/details/99694359

    expand 如何写 umi

    import queryString from 'query-string';
    
    const expandQuery = ['tag', 'menu', 'offering_type', 'pair'];

    export async function getDishDetail(dishId: any): Promise<any> {
      return request(`/api/dish/${dishId}`, {
        method: 'GET',
        headers: { bearLang: 'edit', bearToken: 'auth', bearId: 'bId' },
        params: { expand: expandQuery },
        paramsSerializer: function(params) {
          const serealizedString = params['expand']
            ? queryString.stringify(params, { arrayFormat: 'index' })
            : '';
          return serealizedString;
        },
      });
    }

  • 相关阅读:
    window2003 安全配置
    VirusScan7.0使用说明
    管理者必读的四个小故事
    iis权限设置
    电信增值业务寻找合作伙伴
    ERP项目管理12要点
    抽闲破个案,放松一下(1)
    网站策划,网站建设的重中之重
    企业及时通讯软件源代码销售,功能类似QQ/UC/贸易通
    软件项目实施规范小结
  • 原文地址:https://www.cnblogs.com/cschen588/p/12577860.html
Copyright © 2011-2022 走看看