路飞项目概括
1.vue框架
前台html+css+js框架,是不同于js与jq的数据驱动框架
指令 | 实例成员 | vue项目
2.drf框架
django的插件,完成前后台分离项目后台接口编写的框架
序列化组件 | 三大认证组件 | 分页,筛选,过滤,排序 | 请求,解析,响应
3.路飞项目
前台由vue完成,后台由drf完成的前后台分离项目
git | 短信认证 | celery异步任务 | 项目上线
Vue导读
vue框架
vue是前台框架:Augular、React、Vue
vue:结合其他框架优点、轻量级、中文API、数据驱动、双向绑定、MVVM设计模式、组件化开发、单页面应用
vue环境:本地导入与cdn导入
vue是js渐进式框架
根据开发需求,可以决定vue框架控制项目的具体方位:可以为一个标签,也可以为一个页面,甚至可以为整个项目
实例成员-挂载点
1.vue渐进式框架:控制页面及项目的范围
2.vue的环境导入:本地、cdn
3.vue框架的优点:轻量级、中文API、数据驱动、双向绑定、MVVM设计模式、组件化开发、单页面应用
4.vue如何与html页面的结构建立关联:挂载点
注意:
1.html与body不能作为挂载点
2.一个vue对象挂载点之后索引一个匹配结果,所以挂载点一般用id标识
<body>
{{ }}
<hr>
<div class="main">
{{ }}
</div>
<hr>
<div class="main">
{{ }}
</div>
<div id="wrap">
{{ }}
<hr>
<div class="main">
{{ }}
</div>
<hr>
<div class="main">
{{ }}
</div>
</div>
</body>
<script src="js/vue.js"></script>
<script>
new Vue({
el: '.main' // el表示挂载点
})
new Vue({
el: '#wrap'
})
</script>
<script>
let b = 20;
let dic = {
a:10,
b //b: b 的简写
};
console.log(dic)
</script>
实例成员-数据
1.用实例成员data为vue环境提供数据,数据采用字典{}形式
2.在插值表达式{{ }}中,直接书写数据的key来访问数据
3.在外部通过接受实例的变量app,访问实例成员(实例成员都用$开头),间接访问到数据
app.$data.info
4.在外部也可以通过实例化变量app直接访问数据
app.info
5.在vue实例内部的方法methods中,使用变量,this.info(this其实就是等价于app)
<body>
<div id = 'app'>
<!-- {{}}是插值表达式,中间出现的info是vue变量 -->
<p>{{ info }}</p>
<p>{{ info }}</p>
<p>{{ num }}</p>
<p>{{ arr }}</p>
<p>{{ dic }}</p>
</div>
</body>
<script src="js/vue.js"></script>
<script>
let app = new Vue({
el:'#app',
data: {
info: 'message',
num: 100,
result: true,
arr: [1,2,3,4,5],
dic: {
name:'ZZJ',
hobby:'reading'
}
}
})
</script>
<script>
console.log(app);
console.log(app.$data.info);
console.log(app.info);
</script>
实例成员-过滤器
1.过滤器本身就是数据处理函数,可以将插值表达式中的数据作为参数进行处理,得到的函数返回值就是处理后的结果
2.过滤使用语法{{ ...变量 | 过滤器(...变量) }}
3.过滤器在实例中用filters成员提供
<body>
<div id="app">
<!-- 插值表达式可以直接做简单运算 -->
<p>{{ num + 3.5 }}</p>
<p>{{ msg.split('')[4] }}</p>
<p>{{ num | f1 }}</p>
<p>{{ 10, 20, 30, 40 | f2 }}</p>
<p>{{ 10,20 | f2(50, 80) }}</p>
<p>{{ 120 | f2 }}</p>
</div>
</body>
<script src="js/vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
num: 100,
msg: 'message'
},
filters: {
f1:function (num) {
return num*2
},
f2:function (a,b,c,d) {
console.log(a,b,c,d);
return a + b + c + d
}
}
})
</script>
文本指令
1. 插值表达式 同 v-text指令,渲染普通文本
2. v-html指令可以渲染有html语法的文本,能够解析html语法
3.文本指令中可以渲染 变量 也可以渲染 常量
<body>
<div id="app">
<p>{{ info }}</p>
<!-- v-指令名='变量',变量是需要data提供数据值的 -->
<p v-text="info"></p>
<!-- v-指令名='常量',常量采用常量基本的语法,数字与布尔类型可以直接书写的直接书写,字符串等需要特使符号的需要添加符号-->
<p v-text="123"></p>
<p v-text="true"></p>
<p v-text="'abc' + info"></p>
<p v-text="[1,2,3]"></p>
<!-- v-html可以解析html语法 -->
<p v-html="`<b style='color:red'>嘿嘿嘿</b>`"></p>
<p v-text="'<b>嘻嘻嘻</b>'"></p>
</div>
</body>
<script src="js/vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
info:'data提供的数据'
}
})
</script>
<script>
// js多行字符串 反引号 ``
let s1 = `第一行
第二行
结束行`;
console.log(s1);
let name = 'ZZJ';
let hobby = 'Reading';
let s2 = `
name: ${name}
age: ${hobby}
`;
console.log(s2);
</script>
事件指令
1.语法:v-on:事件名=“函数名(参数)”
2.简写:@事件名=“函数名(参数)”
3.用methods实例成员提供 事件函数 的实现
4.事件参数:函数名 | 函数名() | 函数名(自定义参数) | 函数名($event,自定义参数)
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
body {
/*页面文本不允许选择*/
user-select : none;
}
.low-num {
cursor: pointer;
}
.low-num:hover {
color: red;
}
</style>
</head>
<body>
<div id="app">
<p class="low-num" v-on:click="lowNum">
<span>点击减1</span>
<span>{{ num }}</span>
</p>
<p v-on:dblclick="dblAction">双击</p>
<!-- v:on:事件名="事件函数"可以简写为@事件名="事件函数" -->
<p @mouseover="overAction()">悬浮</p>
<p @mouseover="overAction(10)">悬浮1</p>
<p @mouseover="overAction(10,20)">悬浮2</p>
<p @mouseover="overAction(10,20,$event)">悬浮3</p>
<!--事件传参:
@事件='方法' 默认传入事件对象 $event
@事件='方法()' 不传递任何参数
@事件='方法(参数...)' 只传递自定义参数
@事件='方法($event,参数...)' 自定义传参时传递事件对象
-->
</div>
</body>
<script src="js/vue.js"></script>
<script>
let app = new Vue({
el:'#app',
data:{
num:100,
},
methods:{
lowNum:function () {
this.num -= 1
},
dblAction(ev){
console.log(ev)
},
overAction(a,b,c){
console.log(a,b,c)
}
}
})
</script>
属性指令
1.语法:v-bind:属性名=“变量”
2.v-bind:属性名=“变量”简写:属性名="变量"
3.单值属性绑定::titile="变量" | :id="变量" | :自定义属性="变量"
4.style属性绑定::style="字典变量" | style="{css属性1:变量1,...,css属性n:变量n}"
5.class属性绑定::class="变量" | :class="[变量1,...,变量n]" | :class="{类名:布尔变量}"
<head>
<meta charset="UTF-8">
<title>属性指令</title>
<style>
[index] {
color: orange;
}
.ccc {
background-color: yellowgreen;
color: greenyellow;
border-radius: 50%;
}
.ccc1 {
background-color: yellowgreen;
}
.ccc2 {
color: greenyellow;
}
.ccc3 {
border-radius: 50%;
}
.ttt {
background-color: gold;
color: orange;
}
</style>
</head>
<body>
<div id="app">
<!--1) 语法:v-bind:属性名="变量" -->
<p id="p1" class="p1" style="" title="" index="">属性指令1</p>
<p id="p2" v-bind:class="p1" style="" title="" index="">属性指令2</p>
<p v-bind:index="p1">自定义属性也可以被vue绑定1</p>
<!--2) v-bind:属性名="变量" 简写 :属性名="变量" -->
<p :index="p1">自定义属性也可以被vue绑定2</p>
<p :title="'文本提示'">悬浮文本提示</p>
<!--3) style样式属性绑定 -->
<p :style="myStyle">样式绑定1</p>
<p :style="{backgroundColor: c1, color: c2, 'border-radius': '50%'}">样式绑定2</p>
<!--4) class类属性绑定 -->
<p :class="myc1">样式绑定3</p>
<p :class="[myc2,myc3,myc4,'bbb']">样式绑定4</p>
<!--xxx是类名,是否起作用有布尔类型变量yyy值决定 -->
<p :class="{xxx:yyy}">样式绑定5</p>
<!--案例:点击切换类名是否起作用-->
<p @click="clickAction" :class="{ttt:yyy}">点击切换类</p>
</div>
</body>
<script src="js/vue.js"></script>
<script>
new Vue({
el: '#app',
data: {
p1: 'q1',
myStyle: {
backgroundColor: 'pink',
color: 'deeppink',
'border-radius': '50%'
},
c1: 'cyan',
c2: 'tan',
myc1: 'ccc ddd eee',
myc2: 'ccc1',
myc3: 'ccc2',
myc4: 'ccc3',
yyy: true, // false
},
methods: {
clickAction() {
this.yyy = !this.yyy;
}
}
})
</script>
交互修改文本与样式
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.box {
width: 200px;
height: 200px;
background-color: orange;
}
.center {
text-align: center;
line-height: 200px;
}
.rcenter {
text-align: right;
line-height: 200px;
}
.right {
text-align: right;
}
.top {
line-height: 21px;
}
.bottom {
line-height: calc(400px - 21px);
}
</style>
</head>
<body>
<div id="app">
<div class="box" :class="[c1,{right:r,top:t,bottom:b}]" @mouseover="a1" @mousedown="a2" @mouseup="a3" @mouseout="a4">{{ msg }}</div>
</div>
</body>
<script src="js/vue.js"></script>
<script>
new Vue({
el: "#app",
methods: {
a1(){
this.msg = '被悬浮';
this.c1 = 'center';
this.r = 0;
this.t = 0;
this.b = 0;
},
a2(){
this.msg = '被按下';
this.r = 0;
this.t = 0;
this.b = 0;
},
a3(){
this.msg = '被抬起';
this.c1 = 'center';
this.r = 0;
this.t = 0;
this.b = 0;
},
a4(){
this.msg = '被移开';
this.r = 0;
this.t = 0;
this.b = 0;
}
},
data: {
msg: '',
c1: '',
r:0,
t:0,
b:0,
}
})
</script>
表单指令
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.p1 {
width: 500px;
height: 21px;
background-color: deeppink;
}
</style>
</head>
<body>
<div id="app">
<form action="">
<!-- 对表单标签value进行绑定操作变量,不能时时检测绑定的变量 -->
<input type="text" class="inp1" :value="info">
<input type="text" class="inp2" :value="info">
<p class="p1">{{ info }}</p>
<hr>
<!-- 表单标签的值有v-model="变量"来绑定控制,操作的还是value,但是拥有时时变量值的检测 -->
<input type="text" class="inp1" v-model="info">
<input type="text" class="inp2" v-model="info">
<p class="p1">{{ info }}</p>
<!-- 单选框 -->
性别:
男 <input type="radio" name="sex" value="male" v-model="mysex">
女 <input type="radio" name="sex" value="female" v-model="mysex">
其他 <input type="radio" name="sex" value="others" v-model="mysex">
<p>{{ mysex }}</p>
<!-- 复选框 -->
兴趣爱好:
男 <input type="checkbox" name="hobbies" value="male" v-model="myhobbies">
女 <input type="checkbox" name="hobbies" value="female" v-model="myhobbies">
其他 <input type="checkbox" name="hobbies" value="others" v-model="myhobbies">
<p>{{ myhobbies }}</p>
<hr>
<input type="submit">
</form>
</div>
</body>
<script src="js/vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
info:'123',
isAgree:0,
mysex:'others',
myhobbies:['male','female']
}
})
</script>
</html>