如何把一个vue组件改为ionic/angular组件
同是mvvm框架,他们之间是很相似的,如何你已经熟悉其中的一个,那么另一个也就基本上也就会的差不多了。
一、动态属性、值、事件绑定
vue中使用v-bind:或者之间分号:进行绑定
ng中左括号[]进行绑定
v-model –--->[(ngModel)]
@click ---->(click)
二、条件判断
v-if----->*ngIf
三、显示隐藏
v-show------> [hidden]
四、遍历一组数组进行渲染
v-for="item in items" -----> *ngFor="let item of items"
v-for="(item ,index)in items" -----> *ngFor="let item of dots; index as i"。。。。
父子组件如何传值
1.父组件传值到子组件
<app-header [msg]="msg"></app-header>2. 子组件接受父组件的值
子组件里面通过 @Input 接收父组件传过来的数(需要先引入input模块)--相当于vue的props
3.子组件主动发送数据给父组件
引入Output,EventEmitter
import {Output,EventEmitter} from "@angular/core"; @Output() private childOuter = new EventEmitter();// 子组件主动发送数据this.childOuter.emit("我是子组件的数据");4.在父组件中接收数据
// childOuter即是子组件发送的outer(类似Android中的广播)
<app-index (childOuter)="getData($event)"></app-index> // ts文件中: getData(msg:string) { console.log(msg);// 接收到的数据 }------相当于vue的子组件派发事件到父组件
5.父组件主动调用子组件
方法1
// 引用子组件
<app-index #index></app-index> // 使用子组件中的方法
<button (click)="index.childRun()">调用index中的方法</button>方法2
也可以在ts文件中调用:
// 引用子组件 html文件 <app-index #index></app-index> <button (click)="parentClick(index)">调用index中的方法</button>// ts 文件
parentClick(obj) { obj.childRun(); }方法3
ViewChild主动获取数据 相当于vue 父组件里面对子组件加ref引用找到子组件调用其方法
ViewChild 是属性装饰器,用来从模板视图中获取匹配的元素
页面上#xx ts中@ViewChild(xx)
获取匹配的组件也可以是元素,
组件直接导入 @ViewChild(组件名)
元素页面上加#xx @ViewChild(xx)
参考 http://oomusou.io/angular/viewchild/
子组件里面监听父组件传递过来值的变化
onChanges钩子使用 相当于vue里面的watch
……
ionic/ng常用代码片段
[src]="base64Image" //是否存在 [hidden]="lastImage === null" //是否禁用 [disabled]="lastImage === null" //文案显示互斥 {{isFavourite ? '取消关注' : '关注'}} //元素显示互斥 *ngIf="!isSelf" 渲染与否,切换的时候回重新渲染 如何已经有了class再追加class 而不是替换class <span class="dot" [ngClass]="{active: currentPageIndex === i }" *ngFor="let item of dots; index as i"></span> 替换class <span class="dot" [class]="{active: currentPageIndex === i } 或者 [hidden]=”!isSelf” 不重新渲染只显示隐藏 注意与v-show相反等同于 v-show=’isSelf’ Class显示互斥 <span [ngClass]="{'active':sex===1}" (click)="switchSex(1)"></span><b (click)="switchSex(1)">男</b> <span [ngClass]="{'active':sex===0}" (click)="switchSex(0)"></span><b (click)="switchSex(0)">女</b> 根据布尔值绑定某一属性 [color]="btnDisable===true?'light':''" 注意不能带花括号 下面2种都是不对的 <button ion-button block [color]="{btnDisable===true?'light':''}">下一步</button> <button ion-button block [color]="{'light':btnDisable===true}">下一步</button>
如何把一个vue组件改为ionic/angular组件的更多相关文章
- 做了一个vue的同步tree 的npm组件包
前言:因为现成的tree组件没有找到.亦或是其依赖的其他东西太多,不太合适引入我们的项目,所以自己做了一个.大概样式: 在线例子: https://hamupp.github.io/t-vue-tre ...
- Laravel 项目中编写第一个 Vue 组件
和 CSS 框架一样,Laravel 不强制你使用什么 JavaScript 客户端框架,但是开箱对 Vue.js 提供了良好的支持,如果你更熟悉 React 的话,也可以将默认的脚手架代码替换成 R ...
- 手把手教你实现一个 Vue 进度条组件!
最近在个人的项目中,想对页面之间跳转的过程进行优化,想到了很多文档或 npm 等都用到的页面跳转进度条,于是便想自己去实现一个,特此记录. 来看下 npm 搜索组件时候的效果: so 下面咱们一起动手 ...
- 从零开始开发一个vue组件打包并发布到npm (把vue组件打包成一个可以直接引用的js文件)
自己写的组件 有的也挺好的,为了方便以后用自己再用或者给别人用,把组件打包发布到npm是最好不过了,本次打包支持 支持正常的组件调用方式,也支持Vue.use, 也可以直接引用打包好的js文件, 配合 ...
- 如何写好一个vue组件,老夫的一年经验全在这了【转】 v-bind="$attrs" 和 v-on="$listeners"
如何写好一个vue组件,老夫的一年经验全在这了 一个适用性良好的组件,一种是可配置项很多,另一种就是容易覆写,从而扩展功能 Vue 组件的 API 来自三部分——prop.事件和插槽: prop 允许 ...
- 从零开始徒手撸一个vue的toast弹窗组件
相信普通的vue组件大家都会写,定义 -> 引入 -> 注册 -> 使用,行云流水,一气呵成,但是如果我们今天是要自定义一个弹窗组件呢? 首先,我们来分析一下弹窗组件的特性(需求): ...
- 【万字长文】从零配置一个vue组件库
简介 本文会从零开始配置一个monorepo类型的组件库,包括规范化配置.打包配置.组件库文档配置及开发一些提升效率的脚本等,monorepo 不熟悉的话这里一句话介绍一下,就是在一个git仓库里包含 ...
- 如何抽象一个 Vue 公共组件
之前一直想写一篇关于抽象 Vue 组件的随笔,无奈一直没想到好的例子.恰巧最近为公司项目做了一个数字键盘的组件,于是就以这个为例聊聊如何抽象 Vue 的组件. 先上 Demo 与 源码.(demo最好 ...
- 一个 Vue 的滑动按钮组件
git 地址:https://github.com/SyMind/vue-sliding-button vue-better-slider 一个 Vue 的滑动按钮组件,有关滑动方面的处理借鉴 bet ...
随机推荐
- 【原创】大数据基础之CM5(Cloudera Manager)+CDH5离线安装
CM/CDH 5.16.1 CM官方:https://www.cloudera.com/products/product-components/cloudera-manager.html CDH官方: ...
- 【原创】大叔经验分享(19)spark on yarn提交任务之后执行进度总是10%
spark 2.1.1 系统中希望监控spark on yarn任务的执行进度,但是监控过程发现提交任务之后执行进度总是10%,直到执行成功或者失败,进度会突然变为100%,很神奇, 下面看spark ...
- 使用DBMS_SHARED_POOL包将对象固定到共享池
使用DBMS_SHARED_POOL包将对象固定到共享池2011年06月24日 09:45:00 Leshami 阅读数:5808 版权声明:本文为博主原创文章,欢迎扩散,扩散请务必注明出处. htt ...
- sass创建web项目环境步骤
1)npm创建web前端项目环境步骤 1.新建文件夹,在该文件下进入cmd控制台2.输入命令 npm init 回车3.name:名字只支持小写,不支持大写,将大写的名字改为小写即可4.version ...
- echart 标题配置
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- pandas设置值-【老鱼学pandas】
本节主要讲述如何根据上篇博客中选择出相应的数据之后,对其中的数据进行修改. 对某个值进行修改 例如,我们想对数据集中第2行第2列的数据进行修改: import pandas as pd import ...
- SQL反模式学习笔记6 支持可变属性【实体-属性-值】
目标:支持可变属性 反模式:使用泛型属性表.这种设计成为实体-属性-值(EAV),也可叫做开放架构.名-值对. 优点:通过增加一张额外的表,可以有以下好处 (1)表中的列很少: (2)新增属性时,不需 ...
- Python学习(三十九)—— Django之Form组件
一.构建一个表单 假设你想在你的网站上创建一个简单的表单,以获得用户的名字.你需要类似这样的模板: <form action="/your-name/" method=&qu ...
- P1265 公路修建 最小生成树
题目描述 某国有n个城市,它们互相之间没有公路相通,因此交通十分不便.为解决这一“行路难”的问题,政府决定修建公路.修建公路的任务由各城市共同完成. 修建工程分若干轮完成.在每一轮中,每个城市选择一个 ...
- Android Studio 常用快捷键及常用设置
Android Studio 常用快捷键及常用设置 一.常用快捷键 快捷键 描述 Ctrl + Alt + L 格式化代码 Ctrl + ( +/- ) 展开/折叠 代码块 Ctrl + Shift ...