Maison  >  Questions et réponses  >  le corps du texte

réagir.js - Comment utiliser des espaces réservés pour définir des URL reposantes en javascript? Je connais Angular, mais quelle bibliothèque dois-je utiliser lorsque j'utilise React?

Je sais que c'est comme ça en angulaire

$resource('http://localhost:8080/web/user/:id/oper/:active',{id: '111',active: 'y'})

Qu'est-ce qui est utilisé dans React ? Existe-t-il un package capable de réaliser cette fonction

曾经蜡笔没有小新曾经蜡笔没有小新2686 Il y a quelques jours1224

répondre à tous(2)je répondrai

  • 学习ing

    学习ing2017-07-05 11:02:33

    J'utilise le formulaire http://localhost:8080/web/user/{id}/oper/{active}, qui est le même que le formulaire URL du SpringMvc d'arrière-plan. La méthode de remplacement de chaîne utilise la fonction suivante

    .
    /**
     * 扩展了 String 类型,给其添加格式化的功能,替换字符串中 {placeholder} 或者 {0}, {1} 等模式部分为参数中传入的字符串
     * 使用方法:
     *     'I can speak {language} since I was {age}'.format({language: 'Javascript', age: 10})
     *     'I can speak {0} since I was {1}'.format('Javascript', 10)
     * 输出都为:
     *     I can speak Javascript since I was 10
     *
     * @param replacements 用来替换 placeholder 的 JSON 对象或者数组
     */
    String.prototype.format = function(replacements) {
        replacements = (typeof replacements === 'object') ? replacements : Array.prototype.slice.call(arguments, 0);
        return formatString(this, replacements);
    }
    /**
     * 替换字符串中 {placeholder} 或者 {0}, {1} 等模式部分为参数中传入的字符串
     * 使用方法:
     *     formatString('I can speak {language} since I was {age}', {language: 'Javascript', age: 10})
     *     formatString('I can speak {0} since I was {1}', 'Javascript', 10)
     * 输出都为:
     *     I can speak Javascript since I was 10
     *
     * @param str 带有 placeholder 的字符串
     * @param replacements 用来替换 placeholder 的 JSON 对象或者数组
     */
    var formatString = function (str, replacements) {
        replacements = (typeof replacements === 'object') ? replacements : Array.prototype.slice.call(arguments, 1);
        return str.replace(/\{\{|\}\}|\{(\w+)\}/g, function(m, n) {
            if (m == '{{') { return '{'; }
            if (m == '}}') { return '}'; }
            return replacements[n];
        });
    };

    répondre
    0
  • 黄舟

    黄舟2017-07-05 11:02:33

    J'en ai écrit un moi-même,

    /**
     * 格式化url占位符
     * eg: http://localhost:8080/yunpan/{id}/aaa/{name}
     * urlFormat(url, {id: '111', name: 'yc'})
     * => http://localhost:8080/yunpan/111/aaa/yc
     *
     * @param url
     * @param param
     * @returns {*}
     */
    export const urlFormat = (url, param) => {
        if (param === undefined || param === null || param === {}) {
            return url;
        }
    
        let keys = Object.keys(param);
        for (let key of keys) {
            url = url.replace(new RegExp("\{" + key + "\}", "g"), param[key]);
        }
        return url;
    };

    répondre
    0
  • Annulerrépondre