[TOC]
## 1.vue-cli不是全局有效
如果npm命令在終端任意目錄有效,npm install --global vue-cli成功后而vue命令在除vue.cmd所在目錄外其他目錄無效,需要在系統變量Path中加入vue命令所在目錄,如C:\\Users\\v\_haotzhang\\AppData\\Roaming\\npm\\。
## 2.Please try running this command again as root/Administrator
npm安裝項目依賴包,有時候會報Please try running this command again as root/Administrator. 網上的攻略是改變node\_modules及子文件目錄所有權限為當前用戶。也有可能重復執行命令就好了,出現好幾次第一次執行命令報錯,后面什么都沒干,重復執行命令又好了,暫不清楚原因。使用?npm cache clean --force 命令也有可能解決| 對執行命令所在目錄進行 右擊目錄:管理員取得所有權
## 3.npm命令小結
`npm install --save` 與 `npm install --save-dev`? 一個放在package.json 的`dependencies` , 一個放在`devDependencies`
`-save`和`save-dev`可以省掉你手動修改package.json文件的步驟。
`npm install module-name -save`?自動把模塊和版本號添加到dependencies部分 而`npm install module-name -save-dve`?自動把模塊和版本號添加到devdependencies部分?
正常情況,包管理配置package.json關于同一個包僅會在dependencies 和?devDependencies中的一個存在.如果要替換可以刪了配置重裝.或者替換配置位置重裝.
4.組件template下的第一個dom元素是組件根元素,不能允許有同級的其他元素?
5.vue拿到數據渲染時,如果渲染的dom參與了效果組件,舉例,bootstrap的select UI組件。如果在異步拿到數據后立刻啟動組件,可能組件初始化時,頁面還沒有渲染完成,導致組件初始化失敗。vue提供了監聽數據渲染結束的API,監聽渲染結束再初始化即可。
```
_self.$nextTick(function(){
alert('v-for渲染已經完成');
$(".game_list").selectpicker({
dropuAuto : false
});
})
```
## 6.dom屬性與變量綁定類似?:id="['login_gift_list_'+index]",其中index是變量
? ()里可以寫js表達式,[]內的成員為class成員
:style="{left: x + 'px', top: y + 'px', visibility: show ? 'visible' : 'hidden'}" ?{}花括號也可以寫js表達式,{}比()更好用,()有時候解析表達式會有異常,也可能是我的表達式寫的有問題,日后深入
補充:經實踐,:html屬性名=""中不需要()和{}頁也可以直接寫表達式,有引號被識別為字符串,無引號會在vue實例中匹配同名成員和方法,都沒有會報undefined的方法,()和{}只是提升表達式的優先級,能幫助完成更復雜的表達式,如
?:class="['dlqy_btn', 'btn_'+(personal_conf.medal_gift > 0 ? 'gray':'')]",如果沒有()包裹三元運算符,不會報錯,但是最后整個btn_包括后面的都不會被解析顯示
## 7.術語
{{}}渲染變量叫做插值
vue實例對象綁定的dom元素,叫做掛載元素?
## 8.靜態資源文件熱更新
在vue-cli模式下,如果靜態資源使用link和script標簽來引入樣式和腳本,不會熱更新.?使用import導入支持熱更新.除了src之外的配置修改都需要重新`npm run dev`
## 9.不要使用html標簽作為組件標簽名,他將被識別為html標簽而不是組件,組件標簽的命名僅和當前頁注冊和引用的組件名有關,三個是同步的,注冊和引用的名稱一定相同,假如是駝峰風格,組件標簽應將組件名中的大寫X替換為-x ,如圖2 3必須一致且不為html標簽名
## 10.組件的通信原則
遵循父到子props: ['message'] ?子到父events的單向數據流通信.其中props中聲明的變量,與組件標簽的使用一樣:camelCased (駝峰式) 命名的 prop 需要轉換為相對應的 kebab-case (短橫線隔開式) 命名.通過在子組件標簽中變量綁定的形式傳到子組件的作用域.
11.Uncaught ReferenceError: Vue is not defined;
如果vue.js已經成功載入,實例vue的時候報Uncaught ReferenceError: Vue is not defined;考慮是否頁面其他的js文件沖突了?
## 12.vue-resource攔截器,
如果要在每個請求前或者響應后做統一處理,這個會起到作用,典型的,請求前給個loading效果+遮罩來過渡,響應后再關閉
```
Vue.http.interceptors.push((request, next) => { ?
console.log("請求前統一操作"); ?
console.log("request"); ?????
showLoading = true; ?
next((response) => { ?
console.log("請求后統一操作"); ?
showLoading = false; ?
return response; ?
}) ?
})
```
## 13.為什么要使用組建?
使用非vue-cli開發模式[即script標簽直接引入vue.js]的一個最明顯的問題,如果前后端完全分離,隨著業務增進,全部寫在一個頁面,比如增,改全部使用modal 而不是跳轉,最后html都聚合在一個頁面,前端的代碼會非常大.后期的維護成本巨大.有必要用組件的原因除了重用,還有一個是拆分文件[分解dom],減少維護成本.提升代碼清晰度 ??
## 14.頁面雙倍渲染
IOS9下的vue? 使用json對象迭代的方式迭代數組對象會導致數組的內容翻倍.特征是頁面的數據渲染是雙份的,其他IOS版本不會出現
- 常見功能
- 第三方授權登錄
- 郵件發送
- 簡易聊天室
- 獲取各國匯率
- PHP獲取服務器硬件指標
- 數據上報之
- web開發
- 開發規范
- 前端
- 踩坑
- 將footer固定在底部
- bootstrap
- Metronic
- 用到的jquery插件
- bootstrap-hover-dropdown
- jquery.slimscroll
- jquery.blockui
- bootstrap-switch
- js.cookie
- moment
- bootstrap-daterangepicker
- morris
- raphael
- jquery.waypoints
- jquery.counterup
- select2
- 取值和設置默認值
- vue
- axios
- 瀏覽器
- 谷歌瀏覽器
- 谷歌插件
- layui
- layui-表格
- layui-表單
- layui-彈窗
- layui-分頁
- 后端
- 操作系統
- linux
- 用戶管理
- 文件管理
- 目錄管理
- 壓縮和解壓縮
- 進程查看
- 端口查看
- 開機自啟動服務
- 定時任務
- shell腳本
- 殺掉運行超過指定時長指定服務的進程
- 獲取服務器使用狀態
- bash-shell連接socket
- 自定義快捷命令
- centos-踩坑
- 防火墻
- 軟件
- yum
- vim
- screen
- window
- 語言
- PHP
- 配置優化
- 框架
- thinkphp5.1+
- think命令行
- laravel6.+
- 維護模式
- 根據環境讀取不同配置
- laravel6.+采坑
- laravel坑位
- 數據庫事務
- 任務調度
- 文件權限問題
- 增強框架
- larvel:elastic-search
- 圖形驗證碼
- laravel獲取ip
- 函數
- strtotime
- 正則匹配
- 類
- 接口類與抽象類
- 類相關的關鍵字 - abstract
- 類相關的關鍵字 - interface
- PHP有關類的調用方式"->"與"::"的區別
- 擴展
- 問題歸納
- json_encode和json_decode
- 字符串的運算
- curl
- 優化php效率
- 數組相加合并與array_merge
- 時區轉換
- 不常用特性
- php反射
- 包管理器-composer
- GuzzleHttp
- Python
- Go
- 數據庫
- Redis
- 安裝
- 本地化-數據備份
- php-redis操作
- Mysql
- mysql-命令集合
- 設置終端可訪問
- 數據庫設計
- 用戶基礎信息表
- 踩坑集合
- mysql-2002
- mysql-2054
- 優化策略
- mysql-密碼驗證插件
- 一些牛逼的sql查詢
- topN
- 無限級分類
- Memcache
- MongoDb
- 安裝mongo-server
- 安裝php-mongodb擴展
- 在laravel中使用mongoDB
- 客戶端軟件
- Hbase
- Elasticsearch
- elastic-search
- restfulApi操作es
- web服務器
- 1.nginx
- 配置語法規則
- 配置詳解
- rewrite規則
- request_filename
- 2.apache
- 功能設計
- 加密解密
- Base64
- 對亞馬遜SKU加密
- 兼職項目中的加解密
- 騰訊外包時的加密
- 接口設計
- 接口限流設計
- 分庫分表
- 遍歷展示文件目錄結構
- 時區換算
- 文件切割
- 解析xml字符串
- 項目
- 博客后臺管理
- 亞馬遜廣告API
- 官方指引文檔
- 開發人員中心
- 應用商店
- 第三方庫
- 申請API郵件記錄
- 亞馬遜MWS
- 付款報告
- 亂碼
- 亞馬遜管理庫存報告
- 報告
- 商品
- 入庫
- 履行
- 出庫
- 財務
- 訂單
- 異步任務處理
- 集群如何同步代碼
- 基本開發流程
- 文檔管理
- showdoc
- 運行環境
- 開發環境
- vagrant
- windows上配置安裝
- vagrant安裝插件緩慢
- 更換ssh默認端口映射
- 設置x-shell密碼登錄
- 使用市場的box-homestead
- homestead-7: Box 'lc/homestead'
- 常見問題
- 虛擬環境reboot
- 突然無法使用
- phpStudy
- wamp
- 壓測性能
- VPN
- vultr
- 凌空圖床
- 寶塔
- 自動化部署
- 版本管理軟件鉤子
- 線上環境-LNMP
- centos7
- nginx
- mysql
- mysql開機自啟
- mysql-更換默認端口
- datetime字段類型默認值
- php
- php擴展安裝
- redis
- swoole
- gd
- BCMath
- igbinary
- zstd
- 包管理器:composer
- 優化性能
- nodejs
- 更新gcc版本
- 版本控制
- git
- 常用命令
- gitlab
- 版本管理規范
- 使用阿里云創建遠程倉庫
- git自動化部署
- svn
- 忽略指定文件
- 拉取代碼
- 自動化運維
- jekins
- 容器
- 集群
- 架構設計
- 設計原則
- 閱讀參考
- 代碼規劃
- 架構實戰
- 服務治理
- 權限控制設計
- 具體設計
- 計劃
- 疑問知識點
- 讀書筆記
- 高性能Mysql
- TCP-IP詳解-卷一:協議
- 思考
- php如何實現并發執行
- 對接調用設計
- 如何在瀏覽器上實現插件
- 如何設計一個app結合業務告警
- mysql的where查詢沒有用到索引
- 為啥in查詢比循環嵌套sql的查詢還要慢
- 使用git來創建屬于自己的composer包
- 翻頁獲取數據的時候又新增了數據
- 安全思路
- 月報
- PHP ?? 和 ?: 的區別
- PHP異步執行
- redis集群的目標是什么
- 大文件數據處理
- 性能瓶頸分析
- 命令行里輸出帶顏色的字體
- 面試問題合集
- 基礎
- 安全
- 算法
- 冒泡排序
- 快速排序
- 二分法查詢數組指定成員
- 字符查找匹配
- 令牌桶
- 漏桶
- 計數器
- 代理
- 協議
- http
- 狀態碼
- tcp
- udp
- Oauth2.0
- 設計模式
- 單例模式
- 適配器模式
- 工廠模式
- 觀察者模式
- 流程化
- 地址欄輸入網址到返回網頁的流程
- 題目收集
- 工具
- rabbitMq
- rabbitMQ用戶管理
- 生產者
- 消費者
- 支持TP5.*的think-queue
- 消息丟失
- 消費者報錯
- rabbitMQ配置優化
- 磁盤滿載導致服務掛掉
- PHP類庫
- rabbitMQ踩坑
- navicat
- vscode
- phpstorm
- 激活碼
- markdown
- PHP自定義類庫
- 工具類
- 領導力
- 任務分配
- 代碼組織
- 不要重復
- 避免污染
- 接口定義規范
- 小業務需求
- 獲取充值面額組成
- 監控服務器CPU和內存
- shell腳本版本