- 从Angular4升级到Angular6
西麦smile
接手了一个Angular4的旧项目,第一时间就升级到最新的Angular6版本,因此记录一下彩到的一些坑Angular4到Angular5Angular升级指南在升级指南中选择需要升级的版本和升级到的版本,就可以根据指南来对项目进行升级,因为本来的Angular项目版本是4.4.6,因此升级后运行也没有报错。npminstall@angular/{animations,common,compile
- angular6.1脚手架(angular-cli)
大胡子111
1.安装node.js打开命令行工具输入命令查看安装情况$node-v$npm-v2.初始化项目2.1angular-cli6.1介绍angular-cli是angular的脚手架工具,可以帮助我们编写基础代码、快速搭建开发环境2.2全局安装angularcli$npminstall-g@angular/cli2.3查看angularcli是否安装成功$ngversion2.4创建新项目$ngne
- angular6 利用 ngContentOutlet 实现组件位置交换
880d91446f17
这篇文章主要介绍了angular6利用ngContentOutlet实现组件位置交换(重排),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧ngContentOutlet指令介绍ngContentOutlet指令与ngTemplateOutlet指令类似,都用于动态组件,不同的是,前者传入的是一个Component,后者传入的是一个TemplateRef。首先看一下使用
- angular6 页面传值_Angular6学习笔记17:在路由中传参数和接收参数
局外狗
angular6页面传值
传参数1.在需要传分博累发口小定逻间框加题览果些屏洁动理应参数的组件的类文件(ts文件)中,构造方法中,声明对圈件浏用是刚。它学编套互学工久不都维逻直数构过曾结里总经网屏广明果名象:constructor(privateroute:Router){}2用能境战求道,重件开又是正易里是了些之框.在路由中设置参数(有三种方式求圈分件圈浏第用代是水刚道。的它还)router遇新是直朋能到分览支体调Lin
- 【Angular6】前端搭建
不专业得Cook
前言本次开发使用angular6结合ng-Zorro完成前端的开发。本次组内的前端由我来搭建。本次搭建过程是在前辈的基础上做的,所以有一些可以复用的功能为本次搭建节省了很多的时间,不过这个学习的过程还是很宝贵的。搭建步骤温馨提示(1)angular开发使用,目前实践典型项目有ITOO-PC端/physical-PC端。(2)使用ng-zorro组件库开发。(3)样式使用.less文件,less是一
- Angular6去掉生产环境的console打印
皮卡许
Angular6内置了webpack,使得我们无法自定义的去配置webpack,这种情况下,我们需要去掉生产环境的console打印,就只能重写console系列的方法。步骤如下:angular-cli脚手架里面会有环境文件,包含了开发和生产等,首先,我们需要在这些文件中区分出开发和生产:开发环境image.png生产环境image.png在angular.json文件中,根据环境配置,执行不同的
- Angular6-proxy.config.json实现跨域
月上秦少
需求场景:获取后端api接口数据,需要跨域。有时,后台可能有多个业务,提供不同的API,为了方便管理,需要我们在一个文件里配置好。这样,以后要更改接口时就很方便了。解决方案建立本地代理proxy.config.json文件:angular6项目里新建proxy.config.json文件,放在根目录,proxy.config.json(文件名可以随便取,但建议统一)配置内容,可参考:here。由于
- window环境下安装node.js8+angular6
爱吃biangbiang面
商服node.js
安装node.js81.登录node官网node官网Node.js®isaJavaScriptruntimebuiltonChrome'sV8JavaScriptengine.https://nodejs.org/en2.找到适合自己的版本选择下载安装的时候一键next傻瓜式安装即可设置淘宝镜像:npmconfigsetregistryhttps://registry.npm.taobao.org
- nvm 管理多版本node
码非马
front-endvue.js前端node.jsnpm
由于之前的项目用的是Angular6开发的,依赖node10,新的vue项目用vue3.x,需要更高的node版本,但又不能简单升级node,否则之前的项目就没法在本地跑了,所以查了下相关多版本管理的资料,在这里做个记录。第一步卸载本地已安装的nodejs。第二步,打开githubnvm站点找到windows安装找到下载包下载后,本地安装,win10系统会自动注册环境变量,如果没有,可以手动注册,
- angular6.x--虚拟滚动
Sun____
1.安装@angular/material、@angular/cdkcnpminstall--save@angular/material@angular/cdk2.app.module.ts导入模块import{ScrollingModule}from'@angular/cdk/scrolling';import{MatCardModule}from'@angular/material';impo
- angular6 使用信息提示框toast
白不懂黑的静
Angular6
需求描述:在操作结束后,需要在页面右下角弹出提示信息,且在一定的时间可以自动消失。现有环境:Angular6+bootStrap先看效果:方案:选取了ngx-toastr这个插件集成步骤:1、安装ngx-toastr和它的依赖@angular/animationsnpminstallngx-toastr--savenpminstall@angular/animations--save2、在angu
- 如何在Angular6下使用ng-zorro-antd
cipchk
ng-zorro-antd受限于#10430一直都未发布Angular6版本,虽然早已经准备好#1404。这里的原因是多重的,antd的less版本需要JavaScript的支持,想当初我有想把它转成Scss版本,看到这些我内心是奔溃的。而Less3.x认为支持JavaScript是诡异的,因此提供了一个叫@plugin看起来更没那么诡异来解决less调用JavaScript。这就像三角恋一样,a
- html 双向绑定组件,angular6 自定义组件,实现双向数据绑定
翠袂天寒
html双向绑定组件
在包装输入类型的组件时,我们需要向外暴露数据接口,用户输入和输出,这时候在组件内部定义双向绑定,会大大方便用户的使用。在编写组件之前,首先看一下组件的使用方式和效果:app.component:{{testBinding}}其中binding-test标签是自定义组件,利用[()]符号进行双向绑定,下面p标签显示所绑定的值。效果图如下:binding-test组件绑定的值显示在网页上。编写组件新建
- Angular开发学习笔记:Angular自定义组件实现数据双向绑定
JustWantToFly
Angular开发学习笔记Angular自定义组件数据绑定双向绑定
angular6自定义组件,实现双向数据绑定在包装输入类型的组件时,我们需要向外暴露数据接口,用户输入和输出,这时候在组件内部定义双向绑定,会大大方便用户的使用。在编写组件之前,首先看一下组件的使用方式和效果:app.component:{{testBinding}}其中binding-test标签是自定义组件,利用[()]符号进行双向绑定,下面p标签显示所绑定的值。效果图如下:binding-t
- 【CuteJavaScript】Angular6入门项目(3.编写服务和引入RxJS)
pingan8787
本文目录一、项目起步二、编写路由组件三、编写页面组件1.编写单一组件2.模拟数据3.编写主从组件四、编写服务1.为什么需要服务2.编写服务五、引入RxJS1.关于RxJS2.引入RxJS3.改造数据获取方式六、改造组件1.添加历史记录组件2.添加和删除历史记录七、HTTP改造1.引入HTTP2.通过HTTP请求数据3.通过HTTP修改数据4.通过HTTP增加数据5.通过HTTP删除数据6.通过HT
- angular6.x 引入echarts
edd043a92f7a
chart.jpg前言原文地址:Liang的博客因为angular2+使用==typescript==开发,所以想要使用echarts,必须安装echarts针对angular的插件ngx-echarts。本文案列实际效果如上图。安装ngx-echartsnpminstallecharts--savenpminstallngx-echarts@3.2.0--save注意echarts>=3.xan
- 微信开发之Angular6+Ionic4与JS-SDK
蒹葭乄白露
刚开始接到这个项目时,因为对Angular比较熟悉,所以就选用了Angular6+Ionic4框架构造整个项目,开发界面时一切顺利,到了开发微信JS-SDK的时候就有点懵了,网上关于Angular2~6开发微信JS-SDK的案例一个都找不到,这下就不好办了,这时候再换框架的话就太拖进度了,会被骂死,而且新框架也不一定那么适用。辛辛苦苦配置好服务器之后,开始开发JS-SDK了,从官方平台上下载了de
- angular项目从版本5到10的打怪升级之路
酷恩Queen
angularangularjs
angular项目升级记录如果项目当前版本低于6,需要先升级到6,否则无法使用ngupdate来自动升级,所以推荐先按照下面的方法升级到6注意事项:升级的过程中一定要时刻检查下面几个模块的版本,保证它们是兼容的:node的版本typescript的版本angular的版本antd的版本以及其他依赖库的版本angular6以下版本更新到6:如果使用旧版HttpModule和Http服务,请切换到Ht
- Angular6 导航事件(结合rxjs6)
熊花花姑娘
第一步:import{Router,NavigationEnd}from'@angular/router';第二步:constructor(privaterouter:Router)第三步:
- Angular2 富文本编辑器 ng2-ckeditor 的使用
杀个程序猿祭天
本文介绍如何在Angular中使用ng2-ckeditor控件,示例代码基于angular6.0.2,node8.11.2,ng2-ckeditor4.9.2环境安装组件npminstallng2-ckeditor创建ckeditor.component.tsimport{Component,OnInit,ViewChild}from'@angular/core';@Component({sele
- angular6 中angular.json中参数详解
Van_陈
原创angular前端angularjsangular2
其实我觉得配置项这个东西应该是很简单的,毕竟是配置项,参数拿过来抄一下就行了.又不是写什么样式写什么逻辑的但是吧,居然还真的在网上找不到什么能看的东西,尤其是我现在升级到angular6,就真的找不到什么能看的东西了,于是乎,这个看着感觉随便抄抄的内容让我不得不自己研究一下了.angular-cli的配置文件还留存在angular-cli.json的麻烦移步空降到(angular4及以下)http
- 【Angular】Angula6中的组件通信
Angula6_组件通信本文主要介绍Angular6中的组件通信一、父子组件通信1.1父组件向子组件传递信息方法一在父组件上设置子组件的属性父组件绑定信息子组件接收消息import{Component,OnInit,Input}from'@angular/core';@InputchildTitle:string;方法二父组件调用子组件的方法父组件触发消息子组件接收消息childPrint(){a
- Angular6 配置代理
ChangLau
添加proxy.config.json{"/api":{"target":"http://127.0.0.1:8080/","logLevel":"debug","changeOrigin":true,"pathRewrite":{"^/api":""}}}配置package.json使用npmstart启动"scripts":{"start":"ngserve--proxy-configprox
- 2020-01-03/ng-zerro升级的问题
呼噜噜睡
之前开发了一个简单的web项目,前端使用Angular6+ng-zorro(7)作为开发技术。很长一段闲置了项目,没有进行开发。后面手痒,想继续写写页面,怎料前端框架版本升级这么快,Angular已经到8了,ng-zorro到了8.5。一些过渡性版本不见了,这么时候就只剩下升级版本这一条路了。升级很快完成,ng-zorro的一些废弃组件进行了替换,Angular的一些指令和Serviceprovi
- Angular6 教程_编程入门自学教程_菜鸟教程-免费教程分享
IT民工爱搬砖
笔记
教程简介Angular6是一个JavaScript框架,用于构建JavaScript,html和TypeScript中的Web应用程序和应用程序,它是JavaScript的超集。它是Angular的一个更新版本,相当于angular的6.x版本。Angular6入门教程-从基本到高级概念的简单的步骤了解Angular6,其中包括概述,环境设置,项目设置,组件,模块,数据绑定,事件绑定,模板,指令,
- Angular6 教程_编程入门自学教程_菜鸟教程-免费教程分享
程序员
教程简介Angular6是一个JavaScript框架,用于构建JavaScript,html和TypeScript中的Web应用程序和应用程序,它是JavaScript的超集。它是Angular的一个更新版本,相当于angular的6.x版本。Angular6入门教程-从基本到高级概念的简单的步骤了解Angular6,其中包括概述,环境设置,项目设置,组件,模块,数据绑定,事件绑定,模板,指令,
- Angular6升级到Angular8报错问题的解决合集
目录1.polyfills.ts中reflect文件丢失2.@anguar/http不兼容3.kendoCSS报错4.typescript不兼容问题总结1.polyfills.ts中reflect文件丢失报错如下ERRORin./src/polyfills.tsModulenotfound:Error:Can'tresolve'core-js/es7/reflect'in'E:\AJ\update
- Angular 6
雪儿_2b36
如何安装Angular6最快速简捷的方法是通过AngularCLI,即命令行窗口。安装之前,你需要yarn包管理器或者节点包管理器。为了检测你是否有npm(NodePackageManager),你需要在控制台或者命令行中输入>npm-v如果电脑不识别这条命令,你需要安装NodeJS.安装成功之后,在控制台或命令行中重新输入上条命令,即可成功进入NPM。现在我们可以通过NPM去安装AngularC
- Angular6中出现的父子组件通信问题
Yike_Father
Angular6中出现的父子组件传值,和父组件调用子组件方法出现的子组件获取不到父组件实时数据问题。场景:父组件传数据给子组件用的@Input()传递,父组件调用子组件使用的@ViewChild引用子组件,父组件触发子组件是先执行方法后传参。研究一段时间后,解决方法用子组件的ngOnChanges生命函数去执行子组件方法。如果有其他方法欢迎大家留言!
- 常用开源模版
yxCassiel
1.若依管理系统2.AdminLTE2|Dashboard3.JeeSite4.Metronic-TheUltimateBootstrap&Angular6AdminTheme5.AmazeUI|HTML5跨屏前端框架
- ViewController添加button按钮解析。(翻译)
张亚雄
c
<div class="it610-blog-content-contain" style="font-size: 14px"></div>// ViewController.m
// Reservation software
//
// Created by 张亚雄 on 15/6/2.
- mongoDB 简单的增删改查
开窍的石头
mongodb
在上一篇文章中我们已经讲了mongodb怎么安装和数据库/表的创建。在这里我们讲mongoDB的数据库操作
在mongo中对于不存在的表当你用db.表名 他会自动统计
下边用到的user是表明,db代表的是数据库
添加(insert):
- log4j配置
0624chenhong
log4j
1) 新建java项目
2) 导入jar包,项目右击,properties—java build path—libraries—Add External jar,加入log4j.jar包。
3) 新建一个类com.hand.Log4jTest
package com.hand;
import org.apache.log4j.Logger;
public class
- 多点触摸(图片缩放为例)
不懂事的小屁孩
多点触摸
多点触摸的事件跟单点是大同小异的,上个图片缩放的代码,供大家参考一下
import android.app.Activity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener
- 有关浏览器窗口宽度高度几个值的解析
换个号韩国红果果
JavaScripthtml
1 元素的 offsetWidth 包括border padding content 整体的宽度。
clientWidth 只包括内容区 padding 不包括border。
clientLeft = offsetWidth -clientWidth 即这个元素border的值
offsetLeft 若无已定位的包裹元素
- 数据库产品巡礼:IBM DB2概览
蓝儿唯美
db2
IBM DB2是一个支持了NoSQL功能的关系数据库管理系统,其包含了对XML,图像存储和Java脚本对象表示(JSON)的支持。DB2可被各种类型的企 业使用,它提供了一个数据平台,同时支持事务和分析操作,通过提供持续的数据流来保持事务工作流和分析操作的高效性。 DB2支持的操作系统
DB2可应用于以下三个主要的平台:
工作站,DB2可在Linus、Unix、Windo
- java笔记5
a-john
java
控制执行流程:
1,true和false
利用条件表达式的真或假来决定执行路径。例:(a==b)。它利用条件操作符“==”来判断a值是否等于b值,返回true或false。java不允许我们将一个数字作为布尔值使用,虽然这在C和C++里是允许的。如果想在布尔测试中使用一个非布尔值,那么首先必须用一个条件表达式将其转化成布尔值,例如if(a!=0)。
2,if-els
- Web开发常用手册汇总
aijuans
PHP
一门技术,如果没有好的参考手册指导,很难普及大众。这其实就是为什么很多技术,非常好,却得不到普遍运用的原因。
正如我们学习一门技术,过程大概是这个样子:
①我们日常工作中,遇到了问题,困难。寻找解决方案,即寻找新的技术;
②为什么要学习这门技术?这门技术是不是很好的解决了我们遇到的难题,困惑。这个问题,非常重要,我们不是为了学习技术而学习技术,而是为了更好的处理我们遇到的问题,才需要学习新的
- 今天帮助人解决的一个sql问题
asialee
sql
今天有个人问了一个问题,如下:
type AD value
A  
- 意图对象传递数据
百合不是茶
android意图IntentBundle对象数据的传递
学习意图将数据传递给目标活动; 初学者需要好好研究的
1,将下面的代码添加到main.xml中
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http:/
- oracle查询锁表解锁语句
bijian1013
oracleobjectsessionkill
一.查询锁定的表
如下语句,都可以查询锁定的表
语句一:
select a.sid,
a.serial#,
p.spid,
c.object_name,
b.session_id,
b.oracle_username,
b.os_user_name
from v$process p, v$s
- mac osx 10.10 下安装 mysql 5.6 二进制文件[tar.gz]
征客丶
mysqlosx
场景:在 mac osx 10.10 下安装 mysql 5.6 的二进制文件。
环境:mac osx 10.10、mysql 5.6 的二进制文件
步骤:[所有目录请从根“/”目录开始取,以免层级弄错导致找不到目录]
1、下载 mysql 5.6 的二进制文件,下载目录下面称之为 mysql5.6SourceDir;
下载地址:http://dev.mysql.com/downl
- 分布式系统与框架
bit1129
分布式
RPC框架 Dubbo
什么是Dubbo
Dubbo是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA服务治理方案。其核心部分包含: 远程通讯: 提供对多种基于长连接的NIO框架抽象封装,包括多种线程模型,序列化,以及“请求-响应”模式的信息交换方式。 集群容错: 提供基于接
- 那些令人蛋痛的专业术语
白糖_
springWebSSOIOC
spring
【控制反转(IOC)/依赖注入(DI)】:
由容器控制程序之间的关系,而非传统实现中,由程序代码直接操控。这也就是所谓“控制反转”的概念所在:控制权由应用代码中转到了外部容器,控制权的转移,是所谓反转。
简单的说:对象的创建又容器(比如spring容器)来执行,程序里不直接new对象。
Web
【单点登录(SSO)】:SSO的定义是在多个应用系统中,用户
- 《给大忙人看的java8》摘抄
braveCS
java8
函数式接口:只包含一个抽象方法的接口
lambda表达式:是一段可以传递的代码
你最好将一个lambda表达式想象成一个函数,而不是一个对象,并记住它可以被转换为一个函数式接口。
事实上,函数式接口的转换是你在Java中使用lambda表达式能做的唯一一件事。
方法引用:又是要传递给其他代码的操作已经有实现的方法了,这时可以使
- 编程之美-计算字符串的相似度
bylijinnan
java算法编程之美
public class StringDistance {
/**
* 编程之美 计算字符串的相似度
* 我们定义一套操作方法来把两个不相同的字符串变得相同,具体的操作方法为:
* 1.修改一个字符(如把“a”替换为“b”);
* 2.增加一个字符(如把“abdd”变为“aebdd”);
* 3.删除一个字符(如把“travelling”变为“trav
- 上传、下载压缩图片
chengxuyuancsdn
下载
/**
*
* @param uploadImage --本地路径(tomacat路径)
* @param serverDir --服务器路径
* @param imageType --文件或图片类型
* 此方法可以上传文件或图片.txt,.jpg,.gif等
*/
public void upload(String uploadImage,Str
- bellman-ford(贝尔曼-福特)算法
comsci
算法F#
Bellman-Ford算法(根据发明者 Richard Bellman 和 Lester Ford 命名)是求解单源最短路径问题的一种算法。单源点的最短路径问题是指:给定一个加权有向图G和源点s,对于图G中的任意一点v,求从s到v的最短路径。有时候这种算法也被称为 Moore-Bellman-Ford 算法,因为 Edward F. Moore zu 也为这个算法的发展做出了贡献。
与迪科
- oracle ASM中ASM_POWER_LIMIT参数
daizj
ASMoracleASM_POWER_LIMIT磁盘平衡
ASM_POWER_LIMIT
该初始化参数用于指定ASM例程平衡磁盘所用的最大权值,其数值范围为0~11,默认值为1。该初始化参数是动态参数,可以使用ALTER SESSION或ALTER SYSTEM命令进行修改。示例如下:
SQL>ALTER SESSION SET Asm_power_limit=2;
- 高级排序:快速排序
dieslrae
快速排序
public void quickSort(int[] array){
this.quickSort(array, 0, array.length - 1);
}
public void quickSort(int[] array,int left,int right){
if(right - left <= 0
- C语言学习六指针_何谓变量的地址 一个指针变量到底占几个字节
dcj3sjt126com
C语言
# include <stdio.h>
int main(void)
{
/*
1、一个变量的地址只用第一个字节表示
2、虽然他只使用了第一个字节表示,但是他本身指针变量类型就可以确定出他指向的指针变量占几个字节了
3、他都只存了第一个字节地址,为什么只需要存一个字节的地址,却占了4个字节,虽然只有一个字节,
但是这些字节比较多,所以编号就比较大,
- phpize使用方法
dcj3sjt126com
PHP
phpize是用来扩展php扩展模块的,通过phpize可以建立php的外挂模块,下面介绍一个它的使用方法,需要的朋友可以参考下
安装(fastcgi模式)的时候,常常有这样一句命令:
代码如下:
/usr/local/webserver/php/bin/phpize
一、phpize是干嘛的?
phpize是什么?
phpize是用来扩展php扩展模块的,通过phpi
- Java虚拟机学习 - 对象引用强度
shuizhaosi888
JAVA虚拟机
本文原文链接:http://blog.csdn.net/java2000_wl/article/details/8090276 转载请注明出处!
无论是通过计数算法判断对象的引用数量,还是通过根搜索算法判断对象引用链是否可达,判定对象是否存活都与“引用”相关。
引用主要分为 :强引用(Strong Reference)、软引用(Soft Reference)、弱引用(Wea
- .NET Framework 3.5 Service Pack 1(完整软件包)下载地址
happyqing
.net下载framework
Microsoft .NET Framework 3.5 Service Pack 1(完整软件包)
http://www.microsoft.com/zh-cn/download/details.aspx?id=25150
Microsoft .NET Framework 3.5 Service Pack 1 是一个累积更新,包含很多基于 .NET Framewo
- JAVA定时器的使用
jingjing0907
javatimer线程定时器
1、在应用开发中,经常需要一些周期性的操作,比如每5分钟执行某一操作等。
对于这样的操作最方便、高效的实现方式就是使用java.util.Timer工具类。
privatejava.util.Timer timer;
timer = newTimer(true);
timer.schedule(
newjava.util.TimerTask() { public void run()
- Webbench
流浪鱼
webbench
首页下载地址 http://home.tiscali.cz/~cz210552/webbench.html
Webbench是知名的网站压力测试工具,它是由Lionbridge公司(http://www.lionbridge.com)开发。
Webbench能测试处在相同硬件上,不同服务的性能以及不同硬件上同一个服务的运行状况。webbench的标准测试可以向我们展示服务器的两项内容:每秒钟相
- 第11章 动画效果(中)
onestopweb
动画
index.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/
- windows下制作bat启动脚本.
sanyecao2314
javacmd脚本bat
java -classpath C:\dwjj\commons-dbcp.jar;C:\dwjj\commons-pool.jar;C:\dwjj\log4j-1.2.16.jar;C:\dwjj\poi-3.9-20121203.jar;C:\dwjj\sqljdbc4.jar;C:\dwjj\voucherimp.jar com.citsamex.core.startup.MainStart
- Java进行RSA加解密的例子
tomcat_oracle
java
加密是保证数据安全的手段之一。加密是将纯文本数据转换为难以理解的密文;解密是将密文转换回纯文本。 数据的加解密属于密码学的范畴。通常,加密和解密都需要使用一些秘密信息,这些秘密信息叫做密钥,将纯文本转为密文或者转回的时候都要用到这些密钥。 对称加密指的是发送者和接收者共用同一个密钥的加解密方法。 非对称加密(又称公钥加密)指的是需要一个私有密钥一个公开密钥,两个不同的密钥的
- Android_ViewStub
阿尔萨斯
ViewStub
public final class ViewStub extends View
java.lang.Object
android.view.View
android.view.ViewStub
类摘要: ViewStub 是一个隐藏的,不占用内存空间的视图对象,它可以在运行时延迟加载布局资源文件。当 ViewSt