$router.replace() 不更新浏览器查询字符串
$router.replace() doesn't update browser query string
问题是查询字符串没有显示在浏览器的 URL 栏中。
代码更新查询字符串以跟踪产品配置。
有两种方法 - 第一种选择模型,第二种为该模型设置选项。这是代码(查询字符串的值现在是占位符):
方法:
chooseModel (option) {
this.$router.replace({
path: this.$route.path,
query: {m: 'model'},
})
},
choose (option) {
if (!this.selectedModel) return
let opt = {}
opt[option] = option
this.$router.push({ // I've tried push and replace
path: this.$route.path,
query: Object.assign(this.$route.query, opt),
})
},
计算:
selectedModel () {
return this.$route.query.m
},
当调用 chooseModel
时,浏览器显示的查询字符串应该显示为:http://localhost:8080/custom/?m=model
。但是当调用 choose
时,浏览器显示的查询字符串保持不变。
FWIW,我更改了 chooseModel
中的代码以设置多个查询字符串值,它们都显示出来了。显然它正在尝试修改导致问题的值。
使用调试器我可以看到 $route.query
是正确的 - 它反映了我对查询所做的更改。
我在 Firefox 和 Chrome 上看到了相同的行为,所以它显然不是特定于浏览器的。
我需要做什么才能让浏览器显示更新后的查询字符串?
这是我的错误,但仍然是奇怪的行为。
Because a route is immutable Object.assign()
无法修改。奇怪的是,在我尝试修改查询字符串后,新的路由对象显示了我试图设置的值,即使浏览器没有显示它们。
修复很简单 - 不要尝试修改路由对象:
query: Object.assign({}, this.$route.query, opt)
(感谢 VCavallo 提供新的 link 位置)
问题是查询字符串没有显示在浏览器的 URL 栏中。
代码更新查询字符串以跟踪产品配置。
有两种方法 - 第一种选择模型,第二种为该模型设置选项。这是代码(查询字符串的值现在是占位符):
方法:
chooseModel (option) {
this.$router.replace({
path: this.$route.path,
query: {m: 'model'},
})
},
choose (option) {
if (!this.selectedModel) return
let opt = {}
opt[option] = option
this.$router.push({ // I've tried push and replace
path: this.$route.path,
query: Object.assign(this.$route.query, opt),
})
},
计算:
selectedModel () {
return this.$route.query.m
},
当调用 chooseModel
时,浏览器显示的查询字符串应该显示为:http://localhost:8080/custom/?m=model
。但是当调用 choose
时,浏览器显示的查询字符串保持不变。
FWIW,我更改了 chooseModel
中的代码以设置多个查询字符串值,它们都显示出来了。显然它正在尝试修改导致问题的值。
使用调试器我可以看到 $route.query
是正确的 - 它反映了我对查询所做的更改。
我在 Firefox 和 Chrome 上看到了相同的行为,所以它显然不是特定于浏览器的。
我需要做什么才能让浏览器显示更新后的查询字符串?
这是我的错误,但仍然是奇怪的行为。
Because a route is immutable Object.assign()
无法修改。奇怪的是,在我尝试修改查询字符串后,新的路由对象显示了我试图设置的值,即使浏览器没有显示它们。
修复很简单 - 不要尝试修改路由对象:
query: Object.assign({}, this.$route.query, opt)
(感谢 VCavallo 提供新的 link 位置)