在Angular中,组件属于特殊的指令,它的特殊之处在于它有自己的模板(html)和样式(css)。因此使用组件可以使我们的代码具有强解耦、可复用、易扩展等特性。...针对性投射 如果同时存在几个,那外部内容将如何进行投射呢?...该属性支持 CSS 选择器(标签选择器、类选择器、属性选择器、…)来匹配你想要的内容。...出现原因 ng-content> 不会 "产生" 内容,它只是投影现有的内容。...因此,投影内容的生命周期将被绑定到它被声明的地方,而不是显示在地方。 这也从原理解释了前面那个问题:如果同时存在几个,那外部内容将如何进行投射呢? 这种行为有两个原因:期望一致性和性能。
如果你尝试在 Angular 中编写可重复使用的组件,则可能会接触到内容投射的概念。然后你发现了 ng-content>,并找到了一些关于它的文章,进而实现了所需的功能。...接下来我们来通过一个简单的示例,一步步介绍 ng-content> 所涉及的内容。 简单示例 在本文中我们使用一个示例,来演示不同的方式实现内容投影。...页面中会显示一个或两个框,如果我们包含两个框,它们的内容是显示 1 和 1 或 1 和 2?...The explanation ng-content> 不会 “产生” 内容,它只是投影现有的内容。...因此,投影内容的生命周期将被绑定到它被声明的地方,而不是显示在地方。 这种行为有两个原因:期望一致性和性能。什么 “期望的一致性” 意味着作为开发人员,可以基于应用程序的代码,猜测其行为。
答案是可以的,在 Angular 中引入了内容投影的概念,即通过使用 ng-content> 指令来实现内容投影的功能。 ?...虽然我们实现了内容投影,即把标题和按钮都成功投影到 AuthFormComponent 组件中,但你会发现按钮的位置并不是预期的。那么如何解决这个问题呢?...以上示例我们使用元素选择器,来实现选择性内容投影,最后的运行结果如下: ? 组件投影 ng-content 指令除了支持标准的 HTML 标签外,还支持自定义指令。...ContentChild 上面我们已经介绍了内容投射的相关概念及 ng-content> 指令的常见用法。下面我们来介绍在组件内部,如何获取 ng-content> 投射的内容。...在 Angular 中提供了 ContentChild 装饰器来获取投影的元素。
---- 前言 这一篇我们带来的是关于组件基础使用的最后一块,内容投影和Vue中的插槽很类似,在组件封装的时候非常有用,我们一起来体验一下。 正文 1....投影多块内容/组件 容器组件这样写 使用标签锁定投影位置 使用class锁定投影位置 用自定义组件名称锁定投影位置 使用自定义属性锁定投影位置 编号2 ng-content select...投影子元素 使用ng-container来包裹子元素,减少不必要的dom层,类似vue中的template 容器组件这样写 编号4 ng-content select="question...使用 ng-template 元素,你可以让组件根据你想要的任何条件显式渲染内容,并可以进行多次渲染。在显式渲染 ng-template 元素之前,Angular 不会初始化该元素的内容。...使用ng-container定义我们的投影区块 使用ngTemplateOutlet指令来渲染ng-template元素。 通过内置的动态指令*ngIf来控制是否渲染投影。
演示ngAfterViewInit和ngAfterViewChecked挂钩。 AfterContent 演示如何将外部内容投影到组件中,以及如何区分组件的视图中的投影内容和子组件。...,只能通过使用@ViewChild注解的属性查询子视图来实现。...内容投影 内容投影是一种从组件外部导入HTML内容并将该内容插入组件模板中指定位置的方法。 Angular 1开发人员知道这种技术是跨越式的。 考虑以前的AfterView示例中的这种变化。...它告诉Angular在哪里插入该内容。 在这种情况下,投影内容是来自父级的。 ?...内容投影的指示标记是(a)组件元素标签之间的HTML和(b)组件模板中存在ng-content>标签。 AfterContent挂钩 AfterContent挂钩与AfterView挂钩类似。
ViewChild Angular 为我们提供 ViewChild 和 ViewChildren 装饰器来获取模板视图中匹配的元素。ViewChild 是属性装饰器,用来从模板视图中获取匹配的元素。...现在我们先来更新一下 AuthFormComponent 组件(关于它的出身,可以浏览 “Angular 内容投影” 这篇文章),即把下面的消息提示封装为组件。...Viewchild 和 ElementRef 在 ViewChild 小节,我们使用 @ViewChild(AuthMessageComponent) 装饰器来获取 AuthMessageComponent...组件类,使用 ViewChild 装饰器来获取邮箱输入框的元素引用: @ViewChild('email') email: ElementRef; 最后在 ngAfterViewInit 生命周期钩子中输出...此外还定义了以下引用类型:ElementRef、TemplateRef、ViewRef 、ComponentRef 和 ViewContainerRef 等。
在本文中,我们将向您展示如何使用Angular CLI和PM2 Node.js流程管理器运行Angular应用程序。 这允许您在开发期间连续运行应用程序。...$ node -v $ npm -v 检查Node.js和NPM版本 第2步:安装Angular CLI和PM2 接下来,使用npm包管理器安装Angular CLI和PM2 ,如图所示。...#install PM2 第3步:使用Angular CLI创建Angular项目 现在进入服务器的webroot目录,然后使用Angular CLI创建,构建和提供Angular应用程序(称为sysmon-app...因此,您需要一个流程管理器来控制和管理应用程序:连续(永久地)运行它,并使其能够在系统启动时自动启动,如下一节所述。 在转到下一部分之前,按[Ctl + C]以释放命令提示符来终止该过程。...在本指南中,我们展示了如何使用Angular CLI和PM2流程管理器运行Angular应用程序。
angular 来实现这样的一个组件?...卡片的页眉和页脚只能显示文本; 卡片的主体能够显示任意内容, 也可以是其它组件; 这就是所谓的包含。...创建包含组件 在 angular 中, 所谓的包含就是在定义固定视图模板的同时, 通过 ng-content> 标签来定义一个可以放动态内容的位置。 下面就来实现一个简单的卡片组件。..."> 为了能够在其它组件中使用, 需要在对应的 AppModule 中添加声明: import { NgModule } from '@angular...包含多个位置 使用 select 属性, 可以在一个组件中定义多个包含位置。 现在继续修改卡片组件, 允许页眉和页脚包含动态内容。 <!
在本文中,我们将向您展示如何使用Angular CLI和PM2 Node.js流程管理器运行Angular应用程序。这允许您在开发期间连续运行应用程序。...CLI和PM2 接下来,使用npm包管理器安装Angular CLI和PM2,如图所示。...因此,您需要一个流程管理器来控制和管理应用程序:连续(永久地)运行它,并使其能够在系统启动时自动启动,如下一节所述。...Angular CLI主页:https://angular.io/cli PM2主页:http://pm2.keymetrics.io/ 在本指南中,我们展示了如何使用Angular...CLI和PM2流程管理器运行Angular应用程序。
如何同时使用MEIC和MIX清单? 作者:王浩帆 MEIC清单仅为中国境内的排放清单,但是在模拟全国污染场的案例中,中国周边国家的排放是不容忽视的,因此需要通过MIX清单来对MEIC进行一个补充。...不论是模拟网格分辨率大于等于清单网格分辨率,还是模拟网格分辨率小于清单网格分辨率的情况,同时使用MEIC和MIX清单的关键步骤都是如何将MEIC清单镶嵌到MIX中, 作为一系列新的GeoTIFF文件来作为...因此本部分将重点讲解如何使用工具来完成两个系列GeoTIFF的镶嵌工作。 1.将MIX清单和MEIC清单都转换为GeoTiff格式。...•使用mix_2_GeoTiff.py[3]将MIX清单转换为GeoTiff格式。•使用meic_2_GeoTiff.py[4]将MEIC清单转换为GeoTiff格式。...1.进行空间分配、物种分配和时间分配。 此步骤和第一个教程[8]或第二个教程中的步骤完全相同,不再赘述。
Avada主题常常被我们用来做外贸网站建设的经典主题,这个主题比较强大后台有很多的成品网站的demo模板可以直接导入和使用编辑,也可以自己编辑使用和新建页面等等,总之功能比较强大,但是这类主题呢,安装相对麻烦一些...,还有使用的话需要有一定的基础才好,否则用起来会觉得非常恼火的。...2、我们需要购买或者是去下载avada主题,这个主题同国外很多主题一样,首先可以去官网购买正版,但是一般正版似乎都是可以用很多次的密钥,因此就有了盗版,也有一些汉化或者是优化版本可以选择和使用的,这自己去网上找或者是购买吧...3、在后台外观-主题中选择导入主题,然后启用该主题即可,注意主题包并不是很大,但是有些如果使用了虚拟主机超过上传限制的需要自己设置上传大小限制或者是通过ftp上传解压,然后在启用主题。 ?...Max Input Vars,PHP Post Max Size:等等参数,我们可以在系统状态中查看,不满足的需要设置php配置文件使得其满足需要,然后直接选择demo导入就可以了,这类主题一般不推荐购买和使用廉价的虚拟主机
ngOninit:初始化指令或组件,在angular第一次显示展示组件的绑定属性后调用,该方法只会调用一次 ngDocheck:检测 ngAfterContentInit:当把内容投影进组件之后调用,...第一次调用ngDocheck()之后调用,只调用一次,只适用于组件 ngAfterContentChecked:每次完成被投影组件内容的变更检测之后调用,只适用于组件 ngAfterViewInit...>,这种情况下就可以使用ng-content>tag directive is usedng-content> 7. router.navigate 的使用?...当observable或promise返回data时,我们使用一个临时属性来保存内容。稍后,我们将相同的内容绑定到模板。...如何优化Angular 2应用程序来获得更好的性能? 1)考虑AOT编译。 2)确保应用程序已经经过了捆绑,uglify和tree shaking。
如何在jupyter中同时使用python2和3?...由于我是通过anaconda来安装的Jupyter Notebook,所以首先需要解决Anaconda2(Python2)和Anaconda3(Python3)的共存。...activate py3(py3即之前Python3安装目录文件夹的名字)命令之后,再使用python即可切换至Python3。...这个时候在Jupyter Notebook中其实已经存在了python2和python3两个内核,但是否可用未测试。...网上有教程说,必须激活Jupyter Notebook的内核(ipykernel),这2个版本才可以使用,于是使用官方文档( http://ipython.readthedocs.io/en/stable
在本教程中,我们将学习如何在 Django 项目中有效地管理和使用普通视图和 API 视图。我们将从基础概念开始,逐步深入,涵盖必要的配置、代码示例以及最佳实践。1....Django 提供了强大的视图系统,使得开发者可以轻松地同时处理这两种类型的请求。2. 准备工作在开始之前,请确保你已经具备以下条件:Python 和 Django 环境已经安装和配置。...设置项目和应用首先,创建一个 Django 项目和一个应用(或使用现有的应用)。这里假设我们的项目名为 myproject,应用名为 myapp1。...我们将使用 Django REST Framework 来简化 API 视图的创建和管理。...确保静态文件加载正常,例如在模板中使用 {% static %} 标签引用静态文件。8. 总结通过本教程,你学习了如何在 Django 项目中同时使用普通视图和 API 视图。
这篇来讲讲如何在 Android Studio 上同时用 SVN 和 Git 来管理项目。我知道,你肯定会说我吃饱了撑着,没事找事做,为啥要同时用 SVN 和 Git 来管理项目。...为啥要同时用 SVN 和 Git 管理项目 这小题目也可以叫做使用场景 是这样的,我之所以要同时用两个工具来管理项目,是因为,项目原先是用 SVN 管理的,SVN 虽然使用简单,但分支功能远没有 Git...AS 上同时使用 SVN 和 Git 以上可以说只是完成首次使用的配置而已,接下去才是我们想要的。...但 AS 如果同时使用 SVN 和 Git 的话,Local Changes 这边就只会显示 Git 的本地修改了。...但如果 SVN 和 Git 同时使用,SVN 的 commit 功能就失效了,就只有 Git 的 commit 和 push 可以用,但我们又不需要 Git 的 push,它只作为本地管理使用而已,所以小问题就是在这里了
kill和killall还可以向进程发送特定的系统信号。 使用killall和kill以及ps负责管理和结束被卡住或无响应的流程。...用法 如何使用killall killall命令采用以下形式: killall [process name] killall将终止与指定名称匹配的所有程序。...name] killall -SIGKILL [process name] killall -9 [process name] 如何使用kill kill命令终止其PID指定的各个进程。...在一个kill命令中可以指定多个pid和备用系统信号。...$ kill -l kill 9 查找正在运行的进程 使用像htop或top这样的实用程序来查看进程的实时列表及其对系统资源的消耗。
如何使用数组和链表来实现“队列” 与栈一样,队列(Queue)也是一种数据结构,它包含一系列元素。但是,队列访问元素的顺序不是后进先出(LIFO),而是先进先出(FIFO)。 ? ?...与实现栈的方法类似,队列的实现也有两种方法,分别为采用数组来实现和采用链表来实现。下面分别详细介绍这两种方法。...入队列的时候只需要将待入队列的元素放到数组下标为rear的位置,同时执行rear++,出队列的时候只需要执行front++即可。 ?...在上图中,刚开始队列中只有元素1、2和3,当新元素4要进队列的时候,只需要上图中(1)和(2)两步,就可以把新结点连接到链表的尾部,同时修改pEnd指针指向新增加的结点。...OK,使用链表实现队列到此就搞定。 总结 显然用链表来实现队列有更好的灵活性,与数组的实现方法相比,它多了用来存储结点关系的指针空间。
尽管有许多可用的网络化应用工具,但我们将在此教程中关注如何来安装phpIPAM(IP Address Manager IP地址管理工具)。...同时支持IPv4和IPv6(和其它工具不同,它对IPv6支持得很好) 内建的IPv4和IPv6计算器 支持无类域间路由(CIDR)标记 支持MySQL数据库 子网嵌套 基于用户/组权限 可视化报表工具...在本教程中,我们将在Ubuntu环境中使用Apache来配置phpIPAM。 在Ubuntu上安装phpIPAM 首先,使用apt-get来安装需要的软件包。...的用户名和密码,同时指定基准目录。...# service apache2 restart 完成安装 我们可以使用浏览器来完成phpIPAM的安装。
之前两篇文章介绍了如何在powerbi中添加日期表和时间表: Power BI创建日期表的几种方式概览 在PowerBI中创建时间表(非日期表) 有朋友问到如何将这两个表关联到事实表中。...首先,由于日期表和时间表不能叠加在一起(原因在前文说过了),所以肯定是两张表单独和事实表进行关联,而事实表中日期和时间是在同一列。 ?...因此,我们需要先在powerquery中将日期和时间列拆分为日期列和时间列: 选中日期和时间列-添加列-仅时间、仅日期,添加两列,然后删除原有的列 ? 然后分别将日期表和时间表与事实表建立关联: ?...如果还想让日期和时间处在同一个坐标轴上,那么完全可以将日期和时间的各个维度拖放到坐标轴上进行展示: ?...这样我们就可以同时对日期和时间进行分析了,想分析日期、周、月、年等维度就向上钻取,想分析时、分、秒等维度就可以向下钻取。 ?
from the Windows Command Prompt:上面二者同时配置,但是注意这样会将windows中的find.exe和sort.exe工具覆盖,如果不懂这些尽量不要选择 3)选择换行格式...@163.com" 备注:"userName" 和 "myMailbox@163.com" 分别是你自己的用户名和邮箱。...配置用户名和密码 四. 创建本地管理仓库 1....提交当前工作空间的修改内容 $ git commit -m "XXX" 备注:"XXX" 是提示信息,此提示信息是一定要写的,不仅是规则同时也方便我们记录此次操作的是什么内容。 ?...,此时可以使用如下方法解决 $ git push --all -f 备注:强推即利用覆盖方式将你本地的代码替代 GitHub 仓库内的内容 6.