[英]ng-template and ngTemplateOutlet Angular
I have used #something in <ng-template #something></>
and then i have to make a call to other functionality using #somethingOther from the TS file basically used #somethingOther for <zxing-scanner></>
我已经在<ng-template #something></>
使用#something,然后必须使用TSsome文件中的#somethingOther来调用其他功能,基本上将#somethingOther用于<zxing-scanner></>
when i used [ngTemplateOutlet]
outside <ng-template></>
it give me same model in 2 places. 当我在<ng-template></>
之外使用[ngTemplateOutlet]
它在2个地方给了我相同的模型。 in pop-up aswell in the page bellow my data. 在弹出的页面以及我的数据下面。
Can't anyone help me out with the issue. 谁能帮我解决这个问题。 sample Code 样例代码
<ng-container [ngTemplateOutlet]="modalContent"></ng-container>
<ng-template #modalContent>
<div class="modal-body bg-gray">
<div class="row">
<form [formGroup]="form" (ngSubmit)="onSubmit(form.value)" class="row px-3">
<div class="tab-content col-9 border-0">
<div class="scanner-shell" [hidden]="!hasDevices">
<zxing-scanner #scanning start="true" (scanSuccess)="handleQrCodeResult($event)"></zxing-scanner>
</div>
<div class="form-group">
<label class="text-gray">device Code</label>
<input type="text" value='{{ qrResultString }}'>
</div>
<div class="form-group">
<label class="text-gray">device Name</label>
<input type="text">
</div>
<div class="form-group">
<label class="text-gray">Device Type</label>
</div>
<div class="custom-control custom-checkbox">
<label class="custom-control-label" for="checkboxActive">Active</label>
</div>
</div>
</div>
<div class="col-12 bg-white text-center py-1">
<button [disabled]="!form.valid" class="btn btn-success mr-1" type="submit">
<span *ngIf="!device">Update</span>
<span *ngIf="device">Add</span>
</button>
<button type="button" class="btn btn-danger"
(click)="closeModal()">Cancel</button>
</div>
</form>
</div>
</div>
</ng-template>
I got a solution to this problem. 我已经解决了这个问题。 all i have done is put a hidden div out of ng-template that give all the needed property to the Ts file for the scanning Id inside the template. 我所要做的就是将一个隐藏的div放在ng-template之外,该模板将Ts文件的所有必需属性提供给模板中的扫描ID。 and then used it inside where i wanted to use. 然后在我想使用的地方使用它。
using templateoutletModal
was putting it in two places. 使用templateoutletModal
将其放在两个位置。
<div class='d-none'>
<div class="scanner-shell" [hidden]="!hasDevices">
<zxing-scanner #scanning start="true" (scanSuccess)="handleQrCodeResult($event)"></zxing-scanner>
</div>
</div>
<ng-template #modalContent>
<div class="modal-body bg-gray">
<div class="row">
<form [formGroup]="form" (ngSubmit)="onSubmit(form.value)" class="row px-3">
<div class="tab-content col-9 border-0">
<div class="scanner-shell" [hidden]="!hasDevices">
<zxing-scanner #scanning start="true" (scanSuccess)="handleQrCodeResult($event)"></zxing-scanner>
</div>
<div class="form-group">
<label class="text-gray">device Code</label>
<input type="text" value='{{ qrResultString }}'>
</div>
<div class="form-group">
<label class="text-gray">device Name</label>
<input type="text">
</div>
<div class="form-group">
<label class="text-gray">Device Type</label>
</div>
<div class="custom-control custom-checkbox">
<label class="custom-control-label" for="checkboxActive">Active</label>
</div>
</div>
</div>
<div class="col-12 bg-white text-center py-1">
<button [disabled]="!form.valid" class="btn btn-success mr-1" type="submit">
<span *ngIf="!device">Update</span>
<span *ngIf="device">Add</span>
</button>
<button type="button" class="btn btn-danger" (click)="closeModal()">Cancel</button>
</div>
</form>
</div>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.