欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue-cli 移動端布局和動畫使用詳解

 更新時間:2020年08月10日 09:46:29   作者:芳芳樂  
這篇文章主要介紹了Vue-cli和移動端布局和動畫使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

vue-cli(重點)

vue-cli 是用來管理 vue 項目的工具,可以使用 vue-cli 快速創(chuàng)建項目、啟動項目、編譯項目等操作。

常說的vue全家桶指:vue-cli、vue-router、vuex、vue-resource。

vue的單文件組件擴展名是.vue文件,需要借助vue-loader,才能被正常解析。

vue-cli 3 (新版本)

如果之前安裝過低版本的 vue-cli ,那么命令行執(zhí)行:

npm uninstall vue-cli -g

然后安裝

npm install -g @vue/cli

然后檢查版本

vue --version

創(chuàng)建項目

vue create myapp

命令之后后會讓我們選擇預(yù)設(shè):選默認(rèn)的default即可,Manually指手動自定義,然后選擇npm管理包。

項目創(chuàng)建后,cd進入到項目后,runserve運行項目,這樣在瀏覽器中就可以看到效果了。

cd myapp

npm run serve

然后在 src 目錄下正常的開發(fā)項目就可以了,src/main.js 是入口頁面。

// 設(shè)置為 false 以阻止 vue 在啟動時生成生產(chǎn)提示。

Vue.config.productionTip = false

項目開發(fā)完畢之后,需要打包

npm run build

dist目錄下的文件,就是生產(chǎn)環(huán)境下的文件。

vue-cli 2 (舊版本)

# 舊版本:基于 webpack 創(chuàng)建 vue 項目
npm install vue-cli -g
vue init webpack-simple appname 
cd appname
npm install
npm run dev

npm run build

項目結(jié)構(gòu)及文件介紹

public/index.html 是瀏覽器訪問的入口頁面。

src 目錄下保存的是開發(fā)環(huán)境中的碎片化文件。

package.json

在 package.json 中有 eslintConfig 屬性,修改 rules 規(guī)則,允許項目中使用 console。

"rules": {
 "no-console":"off"
}

如何在項目中使用 axios

在 vue 中,通常使用 axios 來發(fā)起請求,獲取響應(yīng)。

npm install axios -S

每當(dāng)使用 npm install 下載依賴模塊時,最好加上參數(shù) -S 或 -D

-S 表示最終 build 打包時,將 axios 的源碼也合并到一起。

package.json 中有 dependencies 和 devDependencies,分別表示生產(chǎn)環(huán)境依賴,和開發(fā)環(huán)境依賴。

{
 dependencies:{}, # --save 生產(chǎn)環(huán)境 簡寫 -S
 devDependencies:{} # --save-dev 開發(fā)環(huán)境 簡寫 -D
}

// 引入axios
import axios from "axios";

// 直接訪問時,因同源策略,拒絕訪問,報錯
axios.get('http://www.wyyijiaqin.com/').then(res=>{
 console.log(res.data)
})

vue.config.js 的配置

是 vue 項目中的配置頁面,需要自己在項目的根目錄創(chuàng)建。

myapp/
node_modules/
public/
src/
vue.config.js

proxy 代理

前端跨域訪問別人服務(wù)器中的某個文件時,因同源策略的問題,我們的前端拿不到別人的數(shù)據(jù),這時我們可以使用代理的方案來解決此問題。

在項目根目錄,自己創(chuàng)建 vue.config.js 文件,里面寫入:

module.exports = {
 devServer: {
 proxy:{
  "/api": {
  target: "http://www.wyyijiaqin.com",
  pathRewrite: { '^/api': '' },
  changeOrigin: true,
  }
 } 
 }
}

修改 vue.config.js 后,要先 ctrl+c 終止服務(wù),然后 npm run serve 啟動服務(wù)。

那么 vue 中訪問 /api 時,實際就是跨域訪問 http://www.wyyijiaqin.com 了

import axios from "axios";
export default {
 methods:{
 fn(){
  // 直接訪問時,因同源策略,拒絕訪問,報錯
  axios.get('http://www.wyyijiaqin.com/').then(res=>{
  console.log(res.data)
  })
 },
 async fn2(){
  // 代理訪問,能夠拿到數(shù)據(jù)
  var {data} = await axios.get('/api');
  console.log( data )
 }
 }
};

alias 別名

vue.config.js

const path = require("path");
function resolve (dir) {
 return path.join(__dirname, dir)
}

module.exports = {
 chainWebpack: config=>{
 config.resolve.alias
  .set('@$', resolve('src'))
  .set('assets', resolve('src/assets'))
  .set('$comp', resolve('src/components'))
 }
}

使用別名

import HelloWorld from "$comp/HelloWorld.vue";

修改 vue.config.js 后要重新 npm run serve

sass 環(huán)境

npm install sass-loader node-sass --save-dev

然后在vue文件中:

<style scoped lang="scss">
$bg : yellow;
body{
 div{
 background: $bg;
 }
}
</style>

當(dāng)然在 js 文件中也可以使用 import 引入 scss 文件

移動端布局

rem 單位

import 'js/rem.js';

引入 rem.js 文件后,css 中就可以直接寫 rem 單位了,改變移動端設(shè)備時,寬高會等比例更新。

比如 UI 給的設(shè)計稿寬度是 750px 的,其中某個圖片寬為 375px,如果用戶的手機寬度就是750,那么看到的圖片就是375。但是如果用戶的手機是 1500 時,圖片就應(yīng)該顯示 750,需要進行等比縮放。

如果 UI 給的設(shè)計稿寬度是 750px,那么我們應(yīng)該在 rem.js 中執(zhí)行的函數(shù)的參數(shù)設(shè)置為 750 ,這樣設(shè)計稿中的 100px,就等于 1rem 了。

flexbox 布局

彈性盒布局默認(rèn)是橫向分配空間,如果想縱向分配,需設(shè)置 flex-direction: column;

div{
 display: flex;
 justify-content: space-around;
 align-items: center;

 li{
 text-align:center;

 a{
  color:white;
  text-decoration: none;
 }

 .router-link-exact-active{
  color: green !important;
 }
 }
}

font-awesome 字體圖標(biāo)

import './assets/font-awesome-4.7.0/css/font-awesome.min.css';

<font class="fa fa-home"></font>

動畫

transition 過渡

Vue 在插入、更新或者移除 DOM 時,提供多種不同方式的應(yīng)用過渡效果。

transition 是 vue 提供的組件,這個組件的作用是給其子節(jié)點添加動畫效果。

<style>
 @import url(https://cdn.bootcss.com/animate.css/3.7.0/animate.min.css);
 
 .toast{ 
 transform: translate(-50%,-50%); 
 position: fixed; 
 left: 50%;
 top: 50%; 
 background:black;
 color:white;
 }
</style>
<div id="app">
 <button @click="fn">動畫按鈕</button>
 <transition
 enter-class=""
 enter-active-class="animated fadeIn"
 enter-to-class=""
 leave-class=""
 leave-active-class="animated fadeOut"
 leave-to-class=""
 >
 <div class="toast" v-if="isShow">Toast</div>
 </transition>
</div>
<script> 
 var app = new Vue({
 el: '#app',  
 data:{
  isShow:true,  
 },
 methods:{
  fn(){
  this.isShow = !this.isShow;
  }
 }
 })
</script>

解讀:當(dāng)toast對應(yīng)的div被創(chuàng)建到頁面上時,transition會給這個div添加enter相關(guān)的css樣式,當(dāng)toast這個div從頁面上被刪除掉的時候,transition會給這個div添加leave相關(guān)的css樣式,所以transition組件就是做動畫設(shè)置的組件。

v-if 和 v-show 都可以實現(xiàn)動畫。

:duration=“10000” 可設(shè)置動畫時長,單位毫秒。

enter-class 在第一幀之后就刪除了;

enter-to-class 定義進入過渡的結(jié)束狀態(tài)。在元素被插入之后下一幀生效 (與此同時 v-enter 被移除),在過渡/動畫完成之后移除。

transition-group

transition只能有0個或1個子節(jié)點,而transition-group可以有零個或多個子節(jié)點。

循環(huán)渲染時,必須寫key,并且key的值是唯一標(biāo)識符(不要用數(shù)組下標(biāo))。

<div id="app">
 <input type="text" v-model="str" />
 <button @click="fn2">添加</button>
 <transition-group
 enter-class=""
 enter-active-class="animated fadeIn"
 enter-to-class=""

 leave-class=""
 leave-active-class="animated fadeOut"
 leave-to-class=""
 >
 <li v-for="(item) in arr" :key="item.id">
  {{item.val}}
  <input type="button" @click="fn3(item.id)" value="del" />
 </li>
 </transition-group>
</div>
<script> 
 var app = new Vue({
 el: '#app',  
 data:{
  str : "",
  arr : []  
 },
 methods:{
  fn2(){
  this.arr.push({"val":this.str, "id":new Date().getTime()});
  },
  fn3( id ){
  var ind = this.arr.findIndex(obj=>obj.id===id);
  this.arr.splice(ind, 1)
  }
 }
 })
</script>

鉤子函數(shù)

動畫回調(diào)函數(shù)(鉤子函數(shù)),動畫執(zhí)行的過程中,自動觸發(fā)的一些函數(shù)。

既可以寫在 transition 中,也可以寫在 transition-group 中。

<transition
 v-on:before-enter="beforeEnter"
 v-on:enter="enter"
 v-on:after-enter="afterEnter"
 v-on:enter-cancelled="enterCancelled"
 
 v-on:before-leave="beforeLeave"
 v-on:leave="leave"
 v-on:after-leave="afterLeave"
 v-on:leave-cancelled="leaveCancelled"
>

鉤子函數(shù)分兩組:

enter 為創(chuàng)建節(jié)點前自動執(zhí)行、創(chuàng)建節(jié)點過程中自動執(zhí)行、創(chuàng)建節(jié)點完畢時自動執(zhí)行、創(chuàng)建節(jié)點取消時自動執(zhí)行。

leave 為刪除節(jié)點前自動執(zhí)行、刪除節(jié)點過程中自動執(zhí)行、刪除節(jié)點完畢時自動執(zhí)行、刪除節(jié)點取消時自動執(zhí)行。

methods: {
beforeEnter: function (el) {
console.log(‘進入前', el)
},
enter: function (el, done) {
console.log(‘進入…', el)
setTimeout(()=>{ // 要給動畫效果預(yù)留時長,如果瞬間done(),那么看不到動畫效果。
done() // 表示完成動畫
}, 2000)
},
afterEnter: function(el){
console.log(‘進入完成', el)
},
enterCancelled: function(el){
console.log(‘取消進入', el)
}
}

EventBus中央事件總線

解決復(fù)雜組件關(guān)系中,數(shù)據(jù)維護的問題。

以下為 webpack 管理的 vue 項目中,EventBus 的寫法。

eventbus.js

import Vue from 'vue'
const eventbus = new Vue();
export default eventbus;

main.js

import eventbus from './eventbus.js'

Vue.prototype.$eventbus = eventbus

任意組件A(監(jiān)聽事件)

mounted(){ this.$eventbus.$on("fnName", function(payload){ }) }

任意組件B(觸發(fā)事件)

this.$eventbus.$emit("fnName", {a:2})

以上這篇Vue-cli 移動端布局和動畫使用詳解就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 深入理解vuex2.0 之 modules

    深入理解vuex2.0 之 modules

    本篇文章主要介紹了vuex2.0 之 modules,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • 函數(shù)式組件劫持替代json封裝element表格

    函數(shù)式組件劫持替代json封裝element表格

    這篇文章主要介紹了為大家函數(shù)式組件劫持替代json封裝element表格的過程思路及示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • Vue3中watch監(jiān)聽的五種情況詳解

    Vue3中watch監(jiān)聽的五種情況詳解

    watch函數(shù)用于偵聽某個值的變化,當(dāng)該值發(fā)生改變后,觸發(fā)對應(yīng)的處理邏輯,本文將給大家介紹了Vue3中watch監(jiān)聽的五種情況,文中通過代碼示例講解的非常詳細(xì),具有一定的參考價值,需要的朋友可以參考下
    2024-03-03
  • vue實現(xiàn)自定義H5視頻播放器的方法步驟

    vue實現(xiàn)自定義H5視頻播放器的方法步驟

    這篇文章主要介紹了vue實現(xiàn)自定義H5視頻播放器的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • Vue編程格式化代碼屬性自動換行問題

    Vue編程格式化代碼屬性自動換行問題

    這篇文章主要為大家介紹了Vue編程格式化代碼屬性及自動換行問題,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-06-06
  • vue 在methods中調(diào)用mounted的實現(xiàn)操作

    vue 在methods中調(diào)用mounted的實現(xiàn)操作

    這篇文章主要介紹了vue 在methods中調(diào)用mounted的實現(xiàn)操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue?iview?導(dǎo)航高亮動態(tài)設(shè)置方式

    vue?iview?導(dǎo)航高亮動態(tài)設(shè)置方式

    這篇文章主要介紹了vue?iview?導(dǎo)航高亮動態(tài)設(shè)置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue el-autocomplete遠(yuǎn)程搜索下拉框并實現(xiàn)自動填充功能(推薦)

    Vue el-autocomplete遠(yuǎn)程搜索下拉框并實現(xiàn)自動填充功能(推薦)

    在elementui Input輸入框中可以找到遠(yuǎn)程搜索組件,獲取服務(wù)端的數(shù)據(jù)。這篇文章主要給大家介紹Vue el-autocomplete遠(yuǎn)程搜索下拉框并實現(xiàn)自動填充功能,感興趣的朋友一起看看吧
    2019-10-10
  • vue使用docx-preview實現(xiàn)docx文件在線預(yù)覽功能全過程

    vue使用docx-preview實現(xiàn)docx文件在線預(yù)覽功能全過程

    文件在線預(yù)覽是目前移動化辦公的一種新趨勢,下面這篇文章主要給大家介紹了關(guān)于vue?docx-preview實現(xiàn)docx文件在線預(yù)覽功能的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-04-04
  • Vue——解決報錯 Computed property

    Vue——解決報錯 Computed property "****" was assigned to but it ha

    這篇文章主要介紹了Vue——解決報錯 Computed property "****" was assigned to but it has no setter.的方法,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2020-12-12

最新評論