错误:error Unexpected side effect in "sortedData" computed property vue/no-side-effects-in-computed-properties
时间: 2023-06-13 14:02:42 浏览: 188
这个错误是Vue的警告,它提示你在计算属性中执行了副作用操作。计算属性应该只返回计算结果而不应该修改数据。
例如,如果你的计算属性 `sortedData` 对数据进行了排序,那么对数据的修改将会影响到计算属性的值。这种情况下,应该将数据排序的代码放到一个方法中,并在需要的时候调用该方法。
示例代码:
```
<template>
<div>
<ul>
<li v-for="item in sortedItems">{{ item }}</li>
</ul>
</div>
</template>
<script>
export default {
data() {
return {
items: [3, 1, 4, 2],
};
},
computed: {
sortedItems() {
return this.sortData(this.items);
},
},
methods: {
sortData(data) {
return data.sort((a, b) => a - b);
},
},
};
</script>
```
在上面的代码中,我们将 `sortedData` 计算属性改为调用 `sortData` 方法,并将方法返回的排序后的数组作为计算属性的值返回。这样,即使在计算属性中使用了 `items` 数据,对 `items` 的修改也不会影响到计算属性的值。
相关问题
error Unexpected side effect in "sortedData" computed property vue/no-side-effects-in-computed-properties报错怎么改
这个报错是因为在计算属性 `sortedData` 中有副作用,即改变了计算属性外部的变量或状态。解决方法有两种:
1. 将计算属性 `sortedData` 改成方法,即使用 `methods` 定义。这样就不会有副作用的问题了。
2. 如果需要将 `sortedData` 定义为计算属性,可以将副作用代码移动到一个方法中,并在计算属性中调用该方法。例如:
```javascript
computed: {
sortedData() {
return this.getSortedData()
}
},
methods: {
getSortedData() {
// 副作用代码放到这里
// ...
return sortedData
}
}
```
这样就能避免副作用问题,同时也能保持 `sortedData` 的计算属性特性。
70:17 error Unexpected side effect in "defaultActive" computed property vue/no-side-effects-in-computed-properties
c.Init.ExternalTrigConv = ADC_SOFTWARE_START;
hadc.Init.DataAlign = ADC_DATAALIGN_RIGHT;
hadc.Init.NbrOfConversion = 1;
hadc.Init.DMAContinuousRequests = DISABLE;
hadc.Init.EOCSelection = DISABLE;
这个错误是由于在计算属性 "defaultActive" 中出现了意外的副作用导致的。根 if (HAL_ADC_Init(&hadc) != HAL_OK)
{
Error_Handler();
}
sConfig.Channel = ADC_CHANNEL据错误信息 "vue/no-side-effects-in-computed-properties",Vue 的规则不允许在计算属性中出现副_0;
sConfig.Rank = 1;
sConfig.SamplingTime = ADC_SAMPLETIME_3CYCLES;
作用。副作用是指会修改应用程序状态或执行其他非纯函数操作的代码。
要解决这个 if (HAL_ADC_ConfigChannel(&hadc, &sConfig) != HAL_OK)
{
Error_Handler();
}
}
static void错误,你可以将副作用移动到其他地方,例如在触发计算属性之前或使用一个方法来 MX_GPIO_Init(void)
{
GPIO_InitTypeDef GPIO_InitStruct = {0};
__HAL_RCC_GPIOA_CLK_ENABLE();
// 配置处理副作用。这样可以确保计算属性保持纯粹的特性,只返回依赖数据的值而GPIO引脚为模拟输入模式
GPIO_InitStruct.Pin = GPIO_PIN_0;
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG不引起副作用。
你可以尝试以下解决方案:
1. 将副作用移动到一个方法中;
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
}
void Error_Handler(void)
{
while (1)
{
}
}
:
```javascript
methods: {
handleDefaultActive() {
// 执行副作用操作
}
},
computed: {
default#ifdef USE_FULL_ASSERT
void assert_failed(uint8_t *file, uint32_t line)
{
}
#endif /* USE_FULL_ASSERT */
```
Active() {
// 返回计算属性的值
return ...
}
}
```
2. 在需要触发计算属性上述代码是一个简单的ADC(模数转换器)的驱动程序,它使用了STM32的HAL库之前执行副作用操作:
```javascript
watch: {
someData() {
// 执行副作用操作
this。在主循环中,首先启动ADC转换,然后等待转换完成,然后读取转换.defaultActive = ...
}
},
computed: {
defaultActive() {
// 返回计算属性的值
return ...
}
结果并进行处理。最后停止ADC转换并延时一段时间。
请注意,此代码假设你的外}
```
通过将副作用移动到适当的位置,你应该能够解决这个错误。希望部ADC连接到单片机的PA0引脚(ADC_CHANNEL_0)。你可以根据实际情况修改代码以对你有所帮助!如果还有其他问题,请随时提问。
阅读全文