>웹 프론트엔드 >uni-app >uniapp이 데이터 및 솔루션 변경 후 페이지를 렌더링하지 않는 이유

uniapp이 데이터 및 솔루션 변경 후 페이지를 렌더링하지 않는 이유

PHPz
PHPz원래의
2023-04-23 09:13:384948검색

uniapp을 사용하여 프로젝트를 개발할 때 페이지 데이터를 변경한 후 페이지가 자동으로 렌더링되지 않는 문제가 종종 발생합니다. 이러한 상황은 일반적으로 데이터가 페이지에 바인딩되지 않았거나 데이터가 올바르게 수정되지 않았기 때문에 발생합니다.

다음은 데이터 변경 후 페이지가 렌더링되지 않는 몇 가지 이유와 해결 방법입니다.

  1. 데이터가 올바르게 바인딩되지 않았습니다

유니앱에서는 페이지 데이터를 data 속성을 통해 페이지에 바인딩해야 합니다. 데이터가 페이지에 올바르게 바인딩되지 않으면 데이터 변경 후 페이지가 자동으로 렌더링되지 않습니다.

해결책:

페이지의 데이터 속성에서 바인딩해야 하는 데이터를 정의하세요. 예:

export default {
  data() {
    return {
      message: 'Hello uniapp!'
    }
  }
}

페이지에 데이터를 바인딩하려면 페이지에서 {{message}}를 사용하세요.

  1. 데이터 변경 시 setData 메서드는 사용되지 않습니다.

vue에서 데이터를 변경하려면 Vue.set 또는 Vue.$set 메서드를 사용해야 합니다. uniapp에서 데이터를 변경하려면 setData 메서드를 사용해야 합니다.

해결책:

setData 메소드를 사용하여 데이터를 설정하세요. 예:

this.setData({
  message: 'Hello uniapp!'
})
  1. 데이터가 올바르게 수정되지 않았습니다

유니앱에서 setData를 통해 데이터를 수정할 때 수정된 데이터는 원본 데이터가 아닌 복사본이라는 점에 주의해야 합니다. 변경된 데이터가 복사본이 아닌 경우 페이지 렌더링이 트리거되지 않습니다.

해결책:

수정할 데이터가 복사본인지 확인하세요. 일반적으로 Object.Assign 또는 구조 분해 할당을 사용하여 새 데이터를 생성할 수 있습니다.

예:

let newData = Object.assign({}, this.data.message, {content: 'Hello uniapp!'});
this.setData({
  message: newData
})
  1. wx:if 지시문으로 인해 발생한 문제

wx:if 지시문을 사용할 때 조건이 true가 되면 페이지가 다시 렌더링됩니다. 그러나 조건이 false가 되면 페이지 노드가 소멸됩니다. 이때 setData 작업으로 인해 데이터가 렌더링되지 않습니다.

해결책:

wx:if 지시어 대신 wx:else 또는 wx:elif 지시어를 사용하여 페이지 노드가 삭제되지 않도록 하세요. 예:

<view wx:if="{{show}}">
  ...
</view>
<view wx:else>
  ...
</view>

위는 데이터 변경 후 페이지가 렌더링되지 않는 몇 가지 가능한 이유와 해결 방법입니다. 개발 프로세스 중에는 올바른 방법을 사용하여 데이터를 수정하고 데이터가 페이지에 올바르게 바인딩되도록 주의해야 합니다. 동시에, wx:if 명령어가 야기할 수 있는 문제에 주의해야 하며, 가능한 wx:if 명령어 대신 wx:else 또는 wx:elif 명령어를 사용해야 합니다.

위 내용은 uniapp이 데이터 및 솔루션 변경 후 페이지를 렌더링하지 않는 이유의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.