前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【技巧】ionic3善用数据变更检查

【技巧】ionic3善用数据变更检查

作者头像
IT晴天
发布2018-08-20 10:18:05
4460
发布2018-08-20 10:18:05
举报
文章被收录于专栏:ionic3+ionic3+

有时候出现model变更了,但是页面没有更新

这个问题是ng2中的变更检测策略造成的,ng2并没有智能到一有数据变更就能自动检测到的,有些特殊情况,并没有触发ng的变更检测。执行变更检测的一些情况有:组件中的输入发生变化、组件中有事件响应、setTimeOut函数等。

解决办法也很简单,ng支持手动触发变更检测,只要在适当的位置,调用变更检测即可。

场景一

利用Cordova插件加载本地图片显示在html中,有时等很久才显示,以为是插件的问题,但是调试的时候,发现图像数据很快就返回了,那猜想是显示的问题,同时发现,当页面切换到其它页面再切换回来时,图片很快就显示了,所以,认为是ts的绑定数据更新了,但是视图页面却没有更新,这个时候,ChangeDetectorRef就派上用场了。

首先,在ts文件头部添加:

代码语言:javascript
复制
import { Component, ChangeDetectorRef } from '@angular/core';

然后在构造函数里注入:

代码语言:javascript
复制
constructor(private cd: ChangeDetectorRef)

最终在更新变量后,手动调用代码,强制页面检查刷新即可:

代码语言:javascript
复制
this.cd.detectChanges();

场景二

假如我有一个form表单要在页面上提交,而表单数据是通过绑定来获取的,而有时候出现这种情况:orderParams.test更改了,但是提交的表单数据没有相应更新到,这个时候ChangeDetectorRef又上场了。

代码语言:javascript
复制
<form id="frmOnline" action="http://test/main.html" method="post">
    <input type="hidden" readonly="true" name="c_id" value="{{orderParams.test}}">
……

简单说明

那这个神奇的ChangeDetectorRef是什么来的?它其实有如下几个方法:

代码语言:javascript
复制
class ChangeDetectorRef {
  markForCheck(): void
  detach(): void
  detectChanges(): void
  checkNoChanges(): void
  reattach(): void
}

我不在此重复造车轮多做描述了,有兴趣的查看此文吧: http://blog.csdn.net/railsbug/article/details/77239509

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017.08.24 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 场景一
  • 场景二
  • 简单说明
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档