lilishop-uniapp/uview-ui/libs/function/route.js

86 lines
2.9 KiB
JavaScript
Raw Permalink Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

import queryParams from '../../libs/function/queryParams.js';
/**
* 路由跳转
* 注意:本方法没有对跳转的回调函数进行封装
*/
function route(options = {}, params = false) {
let config = {
type: 'navigateTo',
url: '',
delta: 1, // navigateBack页面后退时,回退的层数
params: {}, // 传递的参数
animationType: 'pop-in', // 窗口动画,只在APP有效
animationDuration: 300, // 窗口动画持续时间,单位毫秒,只在APP有效
};
config = Object.assign(config, options);
// 如果url没有"/"开头添加上因为uni的路由跳转需要"/"开头
if (config.url[0] != '/') config.url = '/' + config.url;
// 判断是否有传递显式的参数,Object.keys转为数组并判断长度,switchTab类型时不能携带参数
if (Object.keys(config.params).length && config.type != 'switchTab') {
// 判断用户传递的url中是否带有参数
// 使用正则匹配,主要依据是判断是否有"/","?","="等,如“/page/index/index?name=mary"
// 如果有url中有get参数转换后无需带上"?"
let query = '';
if (/.*\/.*\?.*=.*/.test(config.url)) {
// object对象转为get类型的参数
query = queryParams(config.params, false);
// 因为已有get参数,所以后面拼接的参数需要带上"&"隔开
config.url += "&" + query;
} else {
query = queryParams(config.params);
config.url += query;
}
}
// 简写形式把url和参数拼接起来
if (typeof options === 'string' && typeof params == 'object') {
let query = '';
if (/.*\/.*\?.*=.*/.test(options)) {
// object对象转为get类型的参数
query = queryParams(params, false);
// 因为已有get参数,所以后面拼接的参数需要带上"&"隔开
options += "&" + query;
} else {
query = queryParams(params);
options += query;
}
}
// 判断是否一个字符串,如果是,直接跳转(简写法)
// 如果是中情形,默认第二个参数为对象形式的参数
if (typeof options === 'string') {
if (options[0] != '/') options = '/' + options;
return uni.navigateTo({
url: options
});
}
// navigateTo类型的跳转
if (config.type == 'navigateTo' || config.type == 'to') {
return uni.navigateTo({
url: config.url,
animationType: config.animationType,
animationDuration: config.animationDuration,
});
}
if (config.type == 'redirectTo' || config.type == 'redirect') {
return uni.redirectTo({
url: config.url,
});
}
if (config.type == 'switchTab' || config.type == 'tab') {
return uni.switchTab({
url: config.url,
});
}
if (config.type == 'reLaunch') {
return uni.reLaunch({
url: config.url
});
}
if (config.type == 'navigateBack' || config.type == 'back') {
return uni.navigateBack({
delta: parseInt(config.delta ? config.delta : this.delta)
});
}
}
export default route;