angular4.x项目中遇到的问题和解决方法

**1. **Module not found: Error: Can't resolve './$$_gendir/app/app.module.ngfactory'

ng build --prod 编译时报上述错误 命令更改为ng build --env=prod

**2. **angular-cli修改域名及端口号

找到node_modules/angular-cli/lib/config/schema.json

default值就是默认的端口

**3. **解决input输入框选中下面内容是,框内的背景色变为黄色的bug

input:-webkit-autofill {-webkit-box-shadow: 0 0 0px 1000px white inset;}  --> css解决

4. 解决input输入框内容下面有红色波浪线的bug

spellcheck="false" 添加到html中的input元素内部

5. isNullOrUndefined --> import { isNullOrUndefined } from "util";

如果用这个判断数据类型或数据是都存在等...,清空数据时要用null / undefined;

6. 页面刷新: this.rotate.navigate(["message"]) 页面整体刷新加载: window.location.reload();

7. ... is not a known element: 1. if ... is an Angular component ... 2. if ... is a Web Component ...

这个是没有在module.ts文件里面引入component, 并且import这个component

8. 解决双击变蓝的问题

<style>
  .cancelselect {
    -moz-user-select: none; /*FireFox*/
    -webkit-user-select: none; /*webkit browser*/
    -ms-user-select: none; /*IE10*/
    -khtml-user-select: none; /*早期浏览器*/
    user-select: none;
  }
</style>
<div onselectstart="return false">内容</div>

9. 对其文本: text-align-last: justify; text-align: justify;

10. core.es5.js:350 Uncaught reflect-metadata shim is required when using class

  在ployfills.ts中添加下面两句话 import 'zone.js';  import 'reflect-metadata';

**11. **PrimeNG 一定要在根模块引入 app.module.ts

**12. **报错:If ngModel is used within a form tag, either the name attribute must be set or the formcontrol must be defined as ‘standalone’ in ngModelOptions.

在ng2表单中使用ngModel需要注意,必须带有name属性或者使用 [ngModelOptions]=”{standalone: true}”,二选其一

image

**13. **强制文本一行显示,多出的省略号表示

必须同时应用三个:

text-overflow:ellipsis; 
white-space:nowrap; 
overflow:hidden;

强制两行显示:

overflow : hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;

**14. **"Import declaration conflicts with local declaration of '{0}'": "导入声明与“{0}”的局部声明冲突。",

**15. **textarea不能调整大小的css属性: style=” resize: none ”;

**16. **修改浏览器滚动条的默认样式

/*滚动条 start*/  
   ::-webkit-scrollbar {  
          width: 10px;  
          height: 4px;  
          background-color: #F5F5F5;  
     }  
    /*定义滚动条轨道 内阴影+圆角*/  
     ::-webkit-scrollbar-track {  
          -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3);  
         background: #fff ;  
    }  
  /*定义滑块 内阴影+圆角*/  
   ::-webkit-scrollbar-thumb {
       border-radius: 3px;
       -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.3); 
       background-color:rgba(7, 170, 247, 0.7); 
   }
   ::-webkit-scrollbar-thumb:hover {  
       border-radius: 3px;   
       -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.3);  
       background-color:rgba(7, 170, 247, 1); 
   }

或者 http://blog.csdn.net/zh_rey/article/details/72473284

#scroll::-webkit-scrollbar{/*滚动条整体部分,其中的属性有width,height,background,border等(就和一个块级元素一样)(位置1)*/  
    width:10px; 
    height:10px;  
 }  
 #scroll::-webkit-scrollbar-button{/*滚动条两端的按钮,可以用display:none让其不显示,也可以添加背景图片,颜色改变显示效果(位置2)*/ 
    background:#74D334;  
 }  
 #scroll::-webkit-scrollbar-track{/*外层轨道,可以用display:none让其不显示,也可以添加背景图片,颜色改变显示效果(位置3)*/ 
    background:#FF66D5;  
 }  
 #scroll::-webkit-scrollbar-track-piece{/*内层轨道,滚动条中间部分(位置4)*/  
    background:#FF66D5; 
 }  
 #scroll::-webkit-scrollbar-thumb{/*滚动条里面可以拖动的那部分(位置5)*/  
    background:#FFA711;  
    border-radius:4px;  
 } 
 #scroll::-webkit-scrollbar-corner {/*边角(位置6)*/  
    background:#82AFFF;
 }  
 #scroll::-webkit-scrollbar-resizer  {/*定义右下角拖动块的样式(位置7)*/  
    background:#FF0BEE;  
 }  
 #scroll{  
    scrollbar-arrow-color: #f4ae21; /**//*三角箭头的颜色*/   
    scrollbar-face-color: #333; /**//*立体滚动条的颜色*/ 
    scrollbar-3dlight-color: #666; /**//*立体滚动条亮边的颜色*/ 
    scrollbar-highlight-color: #666; /**//*滚动条空白部分的颜色*/ 
    scrollbar-shadow-color: #999; /**//*立体滚动条阴影的颜色*/  
    scrollbar-darkshadow-color: #666; /**//*立体滚动条强阴影的颜色*/
    scrollbar-track-color: #666; /**//*立体滚动条背景颜色*/ 
    scrollbar-base-color:#f8f8f8; /**//*滚动条的基本颜色*/ 
 }

**17. **Angular2中设置元素的style样式

import { ElementRef } from '@angular/core';
constructor( private el:ElementRef ) { };
this.el.nativeElement.getElementById(' ').style.height = "";

18. Angular2 内嵌循环

datas: Array<any> = [
      { num: 1, date: "2017-04-12", sellNum: "1231234", sellMpney: "1233", returnNum: "24" },
];
getKeys(item) {
       return Object.keys(item);
}

<div *ngFor="let item of datas">
       <div *ngFor="let key of getKeys(item)"> {{ item[key] }}</div>
 </div>

19. Argument of type 'Http' is not assignable to parameter of type 'Http'.Property 'handler' is missing in type 'Http'

image

20. 报错:Error: Cannot find module '@angular-devkit/core' --> 进入项目目录下执行以下代码 npm i --save-dev @angular-devkit/core

21. 更改base路径: "build": "ng build --env=prod --base-href /analysis/"

22. ng2-file-upload插件,如需要添加额外参数:

this.uploader = new FileUploader({
   method: 'POST',
   url: this.baseService.uploadFileUrl,
   additionalParameter: {  // 这里是添加额外参数的地方
      appType: '1'
   },
});

动态更改参数:this.uploader.options.additionalParameter.appType = this.appType;上传文件:

this.uploader.queue[this.uploader.queue.length - 1].onSuccess = (response, status) => {
    if (status == 200) { }  // 上传文件成功
}
this.uploader.queue[this.uploader.queue.length - 1].upload();

23. 报错:Expression has changed after it was checked

在dev模式下,额外增加了一次变化检测,在第一轮变化检测周期结束后,会立即进行第二轮变化检测,对比两次检测值,如果不相同,则认为是变化检测引起的。

在组件中增加这段代码可以去掉这个检查,但是不建议这么做。

import {enableProdMode} from '@angular/core';
enableProdMode();

24. websocket的状态,websocket.readyState 四个值:

0 :对应常量CONNECTING (numeric value 0) 正在建立连接连接,还没有完成。
1 :对应常量OPEN (numeric value 1) 连接成功建立,可以进行通信。
2 :对应常量CLOSING (numeric value 2) 连接正在进行关闭握手,即将关闭。
3 : 对应常量CLOSED (numeric value 3) 连接已经关闭或者根本没有建立。

**25. **websocket的心跳重连

var ws;  //websocket实例
    var lockReconnect = false;  //避免重复连接
    var wsUrl = "ws://10.2.1.202:7888/preview";    // 创立连接   
    function createWebSocket(url) {
        try {
            ws = new WebSocket(url);
            initEventHandle();
        } catch (e) {
            reconnect(url);
        }     
    }
    // 初始化调用
    function initEventHandle() {
        ws.onclose = function () { reconnect(wsUrl); };
        ws.onerror = function () { reconnect(wsUrl); };
        ws.onopen = function () { //心跳检测重置
            heartCheck.reset().start();
        };
        ws.onmessage = function (event) { //如果获取到消息,心跳检测重置; 拿到任何消息都说明当前连接是正常的
            heartCheck.reset().start();
            var data = JSON.parse(event.data);
        }
    }
    function reconnect(url) {
        if(lockReconnect) return;
        lockReconnect = true;
        //没连接上会一直重连,设置延迟避免请求过多
        setTimeout(function () {
            createWebSocket(url);
            lockReconnect = false;
        }, 100);
    }    
    //心跳检测
    var heartCheck = {
        timeout: 1000,//60秒
        timeoutObj: null,
        serverTimeoutObj: null,
        reset: function(){
            clearTimeout(this.timeoutObj);
            clearTimeout(this.serverTimeoutObj);
            return this;
        },
        start: function(){
            var self = this;
            this.timeoutObj = setTimeout(function(){
                //这里发送一个心跳,后端收到后,返回一个心跳消息,onmessage拿到返回的心跳就说明连接正常
                ws.send(msg);
                self.serverTimeoutObj = setTimeout(function(){//如果超过一定时间还没重置,说明后端主动断开了
                    ws.close();//如果onclose会执行reconnect,我们执行ws.close()就行了.如果直接执行reconnect 会触发onclose导致重连两次
                }, self.timeout)
            }, this.timeout)
        }
    }
    // 调用
    createWebSocket(wsUrl);

26. js和jquery的localstroge

JS****下的操作方法

获取键值:localStorage.getItem(‘key’)
设置键值:localStorage.setItem(‘key’,’value’)
清除键值:localStorage.removeItem(‘key’)
清除所有键值:localStorage.clear()
获取键值2:localStorage.keyName
设置键值2:localStorage.keyName = ‘value’

** JQ****下的操作方法(JS****方法前加’window.’****)**

获取键值:window.localStorage.getItem(‘key’)
设置键值:window.localStorage.setItem(‘key’,’value’)
清除键值:window.localStorage.removeItem(‘key’)
清除所有键值:window.localStorage.clear()
获取键值2:window.localStorage.keyName
设置键值2:window.localStorage.keyName = ‘value’

27. 导出csv中文乱码: var uri = 'data:text/csv;charset=utf-8,\uFEFF' + encodeURIComponent(csv);

**28. **在WPF(WinForm)中不能导出文件

cwBrowser.DownloadHandler = new DownloadHandler();
 /// <summary>  
 /// 下载文件  
 /// </summary>  
 public class DownloadHandler : IDownloadHandler
 {
        public void OnBeforeDownload(IBrowser browser, DownloadItem downloadItem, IBeforeDownloadCallback callback)
        {  if (!callback.IsDisposed)  
        {  using (callback)  
            {
                      callback.Continue(@"C:\Users\" +
                            System.Security.Principal.WindowsIdentity.GetCurrent().Name +
                            @"\Downloads\" +
                            downloadItem.SuggestedFileName,
                        showDialog: true);
                    }  
         }  
     }
        public void OnDownloadUpdated(IBrowser browser, DownloadItem downloadItem, IDownloadItemCallback callback)
        {
        //downloadItem.IsCancelled = false;  
     }
        public bool OnDownloadUpdated(CefSharp.DownloadItem downloadItem)
        { 
       return false; 
     }
  }

29. 窗口关闭事件

窗口关闭之后执行的 : <body onUnload="myClose()"> 然后在javascript里定义myClose()方法

窗口关闭之前执行的 :

window.onbeforeunload = onbeforeunload_handler; function onbeforeunload_handler(){ }

window.onbeforeunload = function(event){ alert("关闭窗口") };

区别 : onUnload方法是在关闭窗口之后执行

onbeforeUnload方法是在关闭窗口之前执行

说明 : 两个方法在 页面关闭、刷新、转向新页面 时都触发。

注 : 只在关闭窗口时触发,而页面刷新的时不触发。

30. bootstrap的模态框 点击背景色不取消:

$('#myModal').modal({backdrop: 'static', keyboard: false}); 
data-backdrop="static" data-keyboard="false"

backdrop:static时,空白处不关闭.

keyboard:false时,esc键盘不关闭.

原文来源:https://www.cnblogs.com/una1804/p/9100875.html

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容