代码拉取完成,页面将自动刷新
同步操作将从 jiangdayuan/ace_engine_sync 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
class BasicDataSource implements IDataSource {
private listeners: DataChangeListener[] = [];
private originDataArray: StringData[] = [];
public totalCount(): number {
return 0;
}
public getData(index: number): StringData {
return this.originDataArray[index];
}
registerDataChangeListener(listener: DataChangeListener): void {
if (this.listeners.indexOf(listener) < 0) {
console.info('add listener');
this.listeners.push(listener);
}
}
unregisterDataChangeListener(listener: DataChangeListener): void {
const pos = this.listeners.indexOf(listener);
if (pos >= 0) {
console.info('remove listener');
this.listeners.splice(pos, 1);
}
}
notifyDataReload(): void {
this.listeners.forEach(listener => {
listener.onDataReloaded();
})
}
notifyDataAdd(index: number): void {
this.listeners.forEach(listener => {
listener.onDataAdd(index);
})
}
notifyDataChange(index: number): void {
this.listeners.forEach(listener => {
listener.onDataChange(index);
})
}
notifyDataDelete(index: number): void {
this.listeners.forEach(listener => {
listener.onDataDelete(index);
})
}
notifyDataMove(from: number, to: number): void {
this.listeners.forEach(listener => {
listener.onDataMove(from, to);
})
}
}
class MyDataSource extends BasicDataSource {
private dataArray: StringData[] = [];
public totalCount(): number {
return this.dataArray.length;
}
public getData(index: number): StringData {
return this.dataArray[index];
}
public addData(index: number, data: StringData): void {
this.dataArray.splice(index, 0, data);
this.notifyDataAdd(index);
}
public pushData(data: StringData): void {
this.dataArray.push(data);
this.notifyDataAdd(this.dataArray.length - 1);
}
public reloadData(): void {
this.notifyDataReload();
}
}
@ObservedV2
class StringData {
@Trace message: string;
@Trace imgSrc: Resource;
constructor(message: string, imgSrc: Resource) {
this.message = message;
this.imgSrc = imgSrc;
}
}
@Entry
@Component
struct MyComponent {
private moved: number[] = [];
private data: MyDataSource = new MyDataSource();
aboutToAppear() {
for (let i = 0; i <= 1; i++) {
this.data.pushData(new StringData(`Hello ${i}`, $r('app.media.app_icon')));
}
}
build() {
List({ space: 3 }) {
LazyForEach(this.data, (item: StringData, index: number) => {
ListItem() {
MyComp({ item: item })
}
}, (item: StringData, index: number) => JSON.stringify(item))
}.cachedCount(5)
}
}
@ObservedV2
class V1ToV2 {
@Trace item?: StringData;
}
@Reusable
@Component struct MyComp {
item: StringData = new StringData("1", $r('app.media.app_icon'))
v12v2: V1ToV2 = new V1ToV2()
aboutToAppear(): void {
console.log( "=====reusecomp=====" + JSON.stringify(this.item ));
this.v12v2.item = this.item
}
aboutToReuse(params: ESObject): void {
this.v12v2.item = params["item"] as StringData
console.log( "======Reuse data:" + this.item.message )
}
build() {
MyCompV2({v12v2: this.v12v2})
}
}
@ComponentV2 struct MyCompV2 {
public v12v2?: V1ToV2
get item() : StringData {
return this.v12v2?.item!
}
aboutToAppear(): void {
console.log( "==========" + JSON.stringify(this.item ));
}
build() {
Column() {
Text(this.item!.message).fontSize(50)
.onAppear(() => {
console.info("appear:" + this.item!.message)
})
Image(this.item!.imgSrc)
.width(500)
.height(200)
}.margin({ left: 10, right: 10 })
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。