版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
教学目标理解Vue.js指令的定义与分类。掌握条件渲染指令的使用与注意事项。掌握列表渲染指令v-for的多种定义方法及与key属性配合使用的方法。掌握数据绑定的多种方式。掌握事件处理指令及事件修饰符的使用方法。掌握其它内置指令的作用与使用方法。掌握Vue自定义指令定义与注册的方法。1第3章
Vue.js指令(6学时)教学目标第1章
Vue.js发展概述(1课时)1.掌握常用的Vue.js开发工具。2.掌握Vue.js页面的基本组成。3.学会使用Vue.js3.x编写简易的单页面应用。4.掌握ECMAScript基础语法(重点)。1.1Vue.js简介
Vue.js是一套用于构建用户界面的渐进式框架。Vue.js被设计为可以自底向上逐层应用。Vue.js的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。
当与现代化的工具链以及各种支持类库结合使用时,Vue.js可以开发复杂的SPA(SinglePageApplication)单页应用项目。
尤雨溪(EvanYou)现任职于纽约GoogleCreativeLab。尤雨溪是Vue.js框架的作者,HTML5版Clear(移动应用)的打造人。
理想:从想让自己的工作更有效率,到想自己写一个框架。从提供一个十分简单专注的工具到将一些DOM和JS对象同步,再到开始扩充范围以及将更多的模块加入到生态系统,最终形成一个框架。思政理想还是要有的,万一实现呢?三大前端框架:React、Angular、Vue.js(Github中star最多)三大移动端框架:Flutter、Weex、ReactNativeVue.js发展史和特点易用已经会了HTML、CSS、JavaScript即可阅读指南开始构建应用灵活不断繁荣的生态系统,可以在一个库和一套完整框架之间自如伸缩。高效20kbmin+gzip的运行大小。超快虚拟DOM,最省心的优化。Vue1.0,2014.2-2015.10.27Vue2.0,2016.4.27Vue2.6.x,2019.02.05V3.0,2020.9.18Vue发展简史Vue特点起源于2013年12月自己的实验项目1.2Vue.js生产环境配置Vue.js引入方法<scripttype="text/javascript"src="js/vue.min.js"></script><scriptsrc="/vue@next"></script>安装VueDevtools1.下载并安装Node.js和npm2.从GitHub上下载VueDevtools(解压到vue-devtools-dev)npminstall;npmrunbuild安装Chorme扩展程序(选择shells/chrome文件夹)Firefox和Edge可以直接浏览器安装devtools拓展程序1.2.1Vue.js引入方法61.2.3Node.js环境配置
环境配置主要是为npm配置全局模块安装的路径和缓存cache的路径。默认情况下执行:npminstall*-g。
模块安装到“C:\Users\用户名\AppData\Roaming\npm”(会占用C盘资源)。
为了减轻C盘资源的压力,建议使用以下方法进行优化环境配置。步骤如下:
(1)在指定盘符(设为F:\nodejs)下新建文件夹node_global和node_cache,用作存放安装的全局模块及缓存cache,
(2)在命令行执行下列配置设置命令。npmconfigsetprefix"F:\nodejs\node_global“
npmconfigsetcache"F:\nodejs\node_cache“
安装node.js(v16.14.x以上)71.2.3环境配置示意图(3)设置环境变量。右击“计算机”,依次选择“属性→高级系统设置→高级→环境变量”。在系统变量域中,单击“新建”按钮,在“编辑系统变量”对话框中设置变量名为NODE_PATH、变量值为F:\nodejs\node_global\node_modules。
在“Administrator的用户变量”域中,选择变量Path后,单击“编辑”按钮,将变量值中的C:\Users\Administrator\AppData\Roaming\npm修改为F:\nodejs\node_global。81.2.4创建第一个Vue单页程序(1)Vuev2.X<divid="app"><p>{{message}}--{counter}}</p></div><!--JS部分-->
<script>var
vm=newVue({//创建Vue实例
el:"#app",//定义挂载元素
template:"",//定义模板内容选项
data:{//定义数据选项
message:"HelloVue!",
counter:0,
},
methods:{//定义方法(函数)
},
});</script>
(2)VueV3.x<divid="app"><p>{{message}}</p><p>计数器Counter={{counter}}</p><button@click="add">计数器增1</button></div><script>//第1种方法const{createApp}=Vue;//解构赋值constApp={//定义JS对象-App组件data(){//data选项为函数,return返回变量
return{
message:"HelloVue!",
counter:0,
}; }, methods:{//定义组件中的方法 },};//创建Vue实例,并挂载到DOM上
createApp(App).mount("#app");//也可以创建一个Vue实例,获取data中数据constinstance=app.mount('#app');案例演示:【例1-1、1-2】1.3Vue.js开发工具开发工具VisualStudioCode(VSCode)HBuilderXWebStorm浏览器工具MSEdge(devtools)Mozilla
Firefox(devtools)GoogleChromeVue调试工具DevTools问:掌握这些工具就能够很好地就业吗?答:我们还得了解一下目前企业需求是什么?101.4ECMAScript6.0基础ECMAScript6.0(以下简称ES6)是JavaScript语言的下一代标准,已经在2015年6月正式发布了。它的目标是使得JavaScript语言可以用来编写复杂的大型应用程序,成为企业级开发语言。1.4.1let和const//var的情况
console.log(chu);//输出undefined
var
chu
=
2022;
//let的情况
console.log(bar);//报错ReferenceError
let
bar
=
2;
const
numberArr=[1,2,3,4,5,6,7]
//赋值numberArr.push(10,20,30);
//可以执行console.log(numberArr);
//输出所有元素numberArr=[15,2,3,4,5,6,7]
//报错,不能重新赋值
注意:ES6新增了let命令,用来声明变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效。常量不能重新赋值、不能重复声明、不会被预解析。常量属于块级作用域。对象常量属性可以修改,但对象的引用不能修改。否则会报错。111.4.2解构赋值ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值。解构不成功,变量的值就等于undefined。(1)数组的解构赋值let
[a1,b2,c1]=[100,200,300];//a1=100,b1=200,c1=300
左右两边结构必须一样let
[chu,[[jiu],liang]]=[10,[[20,30],30]];//chu=10,jiu=[20,30],liang=30
let
[,,z]=["chu","jiu","liang"];//z='liang'
let
[x,,y]=[10,20,30]//x=10,y=30,不完全解构let
[head,...tail]=[10,20,30,40]//head=10,tail=[20,30,40]
let
[x,y,...z]=['z']//x='z',y=undefined,z=[]
1.4ECMAScript6.0基础(2)对象的解构赋值let
{bar,foo}={foo:'aaa',bar:'bbb'}//bar='bbb',foo='aaa',变量必须与属性同名才能成功赋值let
{baz}={foo:'aaa',bar:'bbb'}//baz=undefined,解构不成功。
(3)解构赋允许指定默认值let
[foo=true]=[];//foo=true
let
[x,y='b']=['a'];//x='a',y='b'
let
[x,y='b']=['a',undefined];//x='a',y='b'
121.4ECMAScript6.0基础1.4.3箭头函数
(参数)=>{//函数体,return表达式}ES6中,箭头函数就是函数的一种简写形式,使用括号包裹参数,跟随一个“=>”,紧接着是函数体。当箭头函数没有参数或者有多个参数,要用()括起来。当箭头函数函数体有多行语句,用{}包裹起来,表示代码块,当只有一行语句,并且需要返回结果时,可以省略{},结果会自动返回。当箭头函数要返回对象的时候,为了区分于代码块,要用()将对象包裹起来。var
fun=num=>num;
//与第2~4行等价var
fun=function(num){
return
num;
}
var
fn=()=>5
//与第6行等价var
fn=function(){return
5}
var
sum=(num1,num2)=>num1+num2
//与第8~11行等价var
sum=function(num1,num2){
//普通函数console.log(this)//指向Window对象
return
num1+num2
}
Console.log(sum(100,200));//显示300varfun=(id,name)=>({id:id,name:name});//返回对象时,使用()包裹对象注意:箭头函数里面没有this对象,此时的this是外层的this对象,即Window。普通函数中的this指向Window对象。箭头函数中的this指的是函数定义位置的上下文。箭头函数体中的this对象,是定义函数时的对象,而不是使用函数时的对象。131.4.4展开运算符
展开运算符(...)用于取出参数对象所有可遍历属性,然后拷贝到当前对象。//拷贝对象(深拷贝)
let
preson1
=
{
name:
"chujiuliang",
age:
57
}
let
obj1=
{
...preson1
}
//拷贝console.log(obj1)//{
name:
"chujiuliang",
age:
57
}
//合并对象
let
age
=
{
age:
22
}
let
name
=
{
name:
"liming"
}
let
person2
=
{}
person2
=
{
...age,
...name
}
console.log(person2
)
//{age:
22,
name:
"liming"}
//如果person2中原本有name,age属性会被覆盖
1.4.5模板字符串
模板字符串相当于加强版的字符串,用反引号“`”,除了作为普通字符串,还可以用来定义多行字符串,也可以在字符串中加入变量和表达式。1.4ECMAScript6.0基础多行字符串
let
string1
=
`Vue.js,
isveryeasytolearn!`
console.log(string1)//
Vue.
js,
//
isveryeasytolearn!字符串插入变量和表达式。变量名写在${}中,${}中可以放入JavaScript表达式。let
name
=
"Chujiuliang"
let
age
=
57
let
info
=
`My
Name
is
${name},I
am
${age+1}
years
old
next
year.`
console.log(info)
//
My
Name
is
Chujiuliang,I
am
58
years
old
next
year.
字符串中调用函数function
fun(){
return
"ChuJiuLiang!"
}
let
string2
=
`Welcomto${fun()}`
console.log(string2);
//
WelcomtoChuJiuLiang!
Vue.js开发就业前景Web前端开发人才需求量大,供不应求,薪酬高,待遇好,就业前景宽广!
这么好的机会,还等啥?努力学习吧!本章小结本章主要介绍了Vue.js由来及如何配置Vue.js生产环境的方法。对Vue3.x新特性进行讲解。详细讲解了Vue.js引入方法及devtools调试工具的使用方法。结合2个Vue版本,详细介绍Vue实例创建方法、App组件定义及组件内的el、data、methods等常用的选项。对常用的Vue.js开发工具进行了介绍,主要对业界主流的VSCode、HBuilderX进行介绍,在实际开发过程中,可以根据实际工程的需要和个人喜爱去选择合适的开发工具。最后介绍ECMAScript6的一些基础知识。主要包括let和const、解构赋值、箭头函数、展开运算符和模板字符串等方面的基础知识,为后期项目的开发提供基础条件。思考与拓展总结与提高教学目标第2章
Vue.js基础(5课时)1.理解MVVM模式的工作机制2.掌握多种类型数据绑定的方法3.掌握计算属性与方法在使用上的区别(重点)4.学会使用侦听属性处理数据变化的相关事务5.理解生命周期钩子函数在使用上的差异性6.学会定义及使用数据对象7.掌握数据中数组对象的变异与非变异方法(难点)2.1MVVM模式
MVVM是Model-View-ViewModel的简写,它是一种基于前端开发的架构模式,其核心是提供对View和ViewModel的双向数据绑定,这使得ViewModel的状态改变可以自动传递给View,即所谓的数据双向绑定。Angular、React、Vue.js三大主流MVVM框架
在MVVM架构下,View和Model之间并没有直接的联系,而是通过ViewModel进行交互,Model和ViewModel之间的交互是双向的,因此View数据的变化会同步到Model中,而Model数据的变化也会立即反映到View上。ViewModel通过双向数据绑定把View层和Model层连接了起来,而View和Model之间的同步工作完全是自动的,无需人为干涉。
因此开发者只需关注业务逻辑,不需要手动操作DOM,不需要关注数据状态的同步问题,复杂的数据状态维护完全由MVVM来统一管理。
2.1.2MVVM模式的前端框架发展趋势从/@angular/core-vs-angular-vs-react-vs-vue网站上可以查看下载量和使用状态等数据,其下载量和状态对比结果如下图所示。2.1.3MVVM模式的应用(1)
<!--定义View
-->
<div
id="app">
<h3>教材列表</h3>
<ol>
<li
v-for="book
in
books">{{book.bookName}}</li>
</ol>
</div>
案例演示:【例2-1】MVVM模式的应用
<script>
//定义JS数组对象Model,并作为组件内data选项中的books的引用值
var
myModel
=
[
{
bookName:
"Web前端开发技术"
},
{
bookName:
"JSP程序设计"
},
{
bookName:
"计算机网络"
},
];
//
创建Vue实例app,也称为ViewModel,用来连接View与Model
const
app
=
Vue.createApp({
//
定义data选项
data()
{
return
{
books:
myModel,
//
引用JS数组对象
};
},
});
app.mount("#app");
//
挂载到DOM上
</script>
2.1.3MVVM模式的应用(2)案例演示:【例2-2】数据双向绑定与MVVM模式解析<div
id="app">
<fieldset>
<legend>图书信息</legend>
图书名称:<input
type="text"
v-model="bookName"
placeholder="输入图书名称"><br
/>
出版社:<input
type="text"
v-model="press"
placeholder="输入出版社"><br
/>
定价:<input
type="number"
v-model="price"
placeholder="输入定价"><br
/><br
/>
<input
type="submit"
value="提交">
<input
type="reset"
value="重置">
<p>图书名称:{{bookName}}、出版社:{{press}}、定价:{{price}}</p>
</div>
<script
type="text/javascript">
const
app
=
Vue.createApp({
//
Vue实例app
data()
{
return
{
bookName:
'Vue.js前端框架技术与实战',
//给定初始值,视图同步变化
press:
'',
//为空串
price:
0.0
//为0
}
}
});
app.mount('#app');
//
挂载到DOM上
</script>
2.2数据绑定与插值Vue.js中插值分为文本、HTML代码、属性、JavaScript表达式等多种形式。文本插值:<p>我的姓名是{{myName}}。</p>HTML代码:
<p>v-html指令:<spanv-html="htmlCode"></span></p>属性插值:<av-bind:href="url"v-bind:title="title">中国教育和科研计算机网</a>JavaScript表达式插值:<标记名称>{{JS合法表达式}}</标记名称><标记名称>{{5+5*3}}</标记名称><标记名称>{{Math.pow(x,2)+5}}</标记名称><标记名称>{{yesNo?'确定':'取消'}}</标记名称><标记名称>{{message.split('').reverse().join('')}}</标记名称>数据绑定最常见的形式就是使用“Mustache”语法:{{}}。案例演示:【例2-3】插值的综合应用2.3计算属性与方法问题导入:当模板中插入过多的业务逻辑,会使模板过重且后期难以维护。<divid='app'>{{information}}--{{information.split('').reverse().join('')}}</div>基本语法//在Vue实例vm中定义选项computedcomputed:{
businessHandler(){//业务逻辑处理代码returninformation.split('').reverse().join('');
}
【例2-4】计算属性的应用场景(
vue-2-4.html)。
要求:使用计算属性定义maxNumber、minNumber等函数实现从给定数组中找出最大数和最小数。2.3.1计算属性基础应用解决方案:采用计算属性(computed)来处理一些复杂逻辑时非常有用。计算属性定义为函数形式,在一个计算属性里可以完成各种复杂的逻辑,包括运算、函数调用等,最终返回一个结果就可以。2.3.1计算属性基础应用
设计要求:(1)使用计算属性定义maxNumber函数,找出数组中最大数;(2)使用方法定义minNumber函数,找出数组中最小数。比较计算属性和方法的差异性。Methods配置选项:
methods:{
findMaxNumber(){
this.maxNumber=Math.max(...this.numberArr)
}
},计算属性缓存与方法比较计算属性和方法区别:(1)可以将同一函数定义为一个方法(而不是计算属性)。两种方式的最终结果确实是完全相同的。然而,不同的是计算属性是基于它们的响应式依赖进行缓存的。只在相关响应式依赖发生改变时它们才会重新求值。computed是局部渲染,而methods是全部渲染。(2)methods必须需要一定的条件去触发,而computed则不需要,实时响应。(3)computed依赖缓存,如果不需要经常变动时,可使用computed;需要经常变动时,可使用methods。如果需要传参数,就用methods。252.3.2计算属性的setter和gettercomputed属性默认只有getter,但Vue允许设计人员在需要时可以为其提供一个setter。
在computed选项下设置setter,页面信息会立即渲染,并完成更新工作。如果使用methods选项,并为其定义相同的方法set(),只有调用时才能完成更新工作。//在Vue实例vm对象中定义
computed:{
myObject:{//myObject定义为对象
set:function(newValue){//对新值进行相关业务逻辑处理 },
get:function(){return相关参数(表达式);}}}定义setter时,需要定义成带参数的set,参数为newValue,其值为字符串,渲染时可从中提取相关信息即可。必须在computed属性下,必须定义一个对象,如myObject,用于包裹set和get函数。然后通过赋值语句(或在调试状态下)给myObject赋值,实现数据的变化。案例演示:【例2-5】计算属性的setter和getter属性应用实战-更新图书/定价信息26更新图书/定价信息<div
id="app">
<p
v-once>初始信息:图书名称/定价:{{bookName}}/{{price}}元</p>
<h4>computed设置后立即更新:</h4>
<p>图书名称/定价:{{bookName}}/{{price}}元</p>
<button
type="button"
v-on:click="set()">set方法更新</button>
<p>图书名称/定价:{{bookName}}/{{price}}元</p>
<p
v-once>初始图书名称/定价:{{myBooks}}元</p>
<p>更新后图书名称/定价:{{myBooks}}元</p>
</div>
<script
type="text/javascript">
const
App
=
{
data()
{
return
{
bookName:
"Web前端开发技术",
price:
59.5,
};
},
computed:
{
myBooks:
{
set:
function
(newValue)
{
//
重新设置
var
newBook
=
newValue.split("
");
this.bookName
=
newBook[0];
this.price
=
newBook[newBook.length
-
1];
},
get:
function
()
{
//
取志愿
return
this.bookName
+
"/"
+
this.price;
},
},
},
methods:
{
set:
function
()
{
//
通过方法来赋值
this.bookName
=
"Vue.js前端框架技术与实战";
this.price
=
69.8;
},
},
};
Vue.createApp(App).mount("#app");
</script>
2.4侦听属性watch-1问题导入:有时需要在数据发生变化时,执行一些特定的指令操作,该如何处理呢?解决方案:Vue提供更通用的方法,通过watch选项来响应数据的变化。watch可以为实例添加被观察的对象,并在对象被修改时调用设计人员自定义的方法。watch可以观察简单变量、数组和对象变化,但使用方法略有不同。2.4.1watch属性基本用法
在watch选项中,需要将变量changeValue定义为函数变量,参数分别为newValue、oldValue。其中newValue是变化后的值,oldValue为变化之前的值。//HTML部分<p>需要侦听的绑定数据变量:{{changeValue}}</p>//在JS部分,Vue组件中定义
watch:{changeValue(newValue,
oldValue){//侦听数据变化需要处理的业务逻辑代码} }//通过实例修改data中的数据constinstance=Vue.createApp(App).mount("#app");instance.changeValue=5000;//立即触发侦听案例演示:【例2-6】微信零钱变更动项目实战28【例2-6】微信零钱变更动项目实战
<div
id="app">
<h3>微信钱包变更通知</h3>
<p>微信帐号:202208200111199</p>
<p
v-once>零钱:{{change}}</p>
消费支付:<input
type="text"
name=""
id=""
v-model="money"
/>
<button
type="button"
v-on:click="changeMoney()">支付{{money}}元</button>
<p
style="font-size:
22px">
<img
src="wxlq.jpg"
/>消费后零钱:{{change}}元
</p>
<h3>以下是消费明细帐</h3>
<hr
/>
</div>
<div
id="detail"></div>
<script
type="text/javascript">
const
App
=
{
data()
{
return
{
change:
50000,
money:
300,
loop:
0,
};
},
watch:
{
change(newValue,
oldValue)
{
alert("零钱由
:"
+
oldValue
+
"
变为
"
+
newValue
+
"元!");
//
告警输出前后值
},
},
methods:
{
changeMoney()
{
this.loop
=
this.loop
+
1;
//
统计次数
this.change
=
this.change
-
this.money;
//
变更零钱
this.writeDetail();
//
计入明细帐
},
getElemet(id)
{
return
document.getElementById(id);
//
返回指定id的元素
},
writeDetail()
{
this.getElemet("detail").innerHTML
+=
"<p>第"
+
this.loop
+"次,
消费"
+
this.money
+
"元,零钱为¥:"
+
this.change
+
"元</p>";
//
生成明细帐
},
},
};
constinstance=Vue.createApp(App).mount("#app");
instance.change=35000;//立即触发侦听
</script>2.4.2watch属性高级用法
通常情况下,watch属性并不关心第一次绑定的数据,也不会执行监听函数。只有数据发生改变才会执行。
如果需要在最初绑定值时就能执行函数,则就需要使用handler方法和immediate属性,并将immediate:true。如果还需要尝试侦听数据的变化,还需要设置deep:true。deep:
false(默认值),表示不进行深度监听;true时,表深度侦听。任何修改changeValue里面任何一个属性都会触发这个监听器里的handler。
注意:watch深度监听对象或数组的变化,在变更(不是替换)对象或数组时,旧值将与新值相同。//HTML部分<p>需要侦听的绑定数据变量:{{changeValue}}</p>//在JS部分//Vue实例watch选项中定义
watch:{changeValue:{handler(newValue,oldValue){//处理代码},deep:true,//深度侦听
immediate:true//立即先去执行handler方法}}constinstance=Vue.createApp(App).mount("#app");//定义实例instance.tuition=5000;//基础数据类型-数值="张晓娟";//基础数据类型-字符串//控制台修改方法instance.$data.tuition=4500案例演示:【例2-7】watch属性的高级应用2.5生命周期钩子函数2.5.1生命周期钩子函数作用
//在Vue实例中定义以下选项beforeCreate:function(){}created:function(){}beforeMount:function(){}mounted:function(){}beforeUpdate:function(){}updated:function(){}beforeUnmount:function(){}unmounted:function(){}renderTriggered(event){}//虚拟DOM被触发渲染时调用renderTracked(event){}//虚拟DOM重新渲染时调用
2.5.1-Vue生命周期流程图-2-5.png案例演示:【例2-8】生命周期钩子函数综合应用
beforeCreate()
{
console.log("子组件创建前...");
},
created()
{
console.log("子组件创建啦!");
},
beforeMount()
{console.log("子组件挂载前...");
},
mounted()
{
console.log("子组件挂载啦!");
},
beforeUpdate()
{
console.log("子组件更新前...");
},
updated()
{
console.log("子组件挂载啦!");
},
beforeUnmount(){
console.log("子组件卸载前...");
},
unmounted(){
console.log("子组件卸载啦!");
},
2.6Vue中数组变动更新问题导入:当数组元素发生变化时,需要及时渲染到页面上去,但不是所有方法都能够触发视图更新的。constinstance=Vue.createApp(App).mount('#app');instance.items[indexOfItem]=newValue//利用索引赋值instance.items.length=newLength//直接修改数组的长度Vue.js针对这两个问题给出了相应的解决办法,使用这些方法,可以触发状态更新。使用Vue全局方法Vue.set()或者使用instance.$set()实例方法。参见“2.7.2Vue实例属性与方法”小节。使用数组变异方法。例如push()、unshift()、splice()、pop()、shift()、sort()、reverse()。使用非变异方法。例如filter()、concat()、slice()。constinstance=Vue.createApp(App).mount('#app'); letnewItems=instance.items.slice(1,3)案例演示:【例2-9】数组元素更新方法的应用2.7控制台console对象2.7.1显示信息的命令
显示信息的命令console.log("HelloWorld");("这是info");console.debug("这是debug");//只有显示级别为verbose时才显示信息console.warn("这是warn");console.error("这是error");【语法说明】console.log():用来显示信息。():显示一般信息;console.debug():与consol
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 租借游艇问题课程设计
- 算法综合设计课程设计
- 补货管理的优化与实施方案计划
- 健身器材销售业绩总结
- 2024年烟花爆竹安全的应急预案
- 银行工作总结创新发展成果彰显
- 医药包材采购心得总结
- 娱乐活动行业顾问工作总结提升娱乐活动吸引力
- 服务业会计工作内容分析
- 2024年设备的管理制度范本
- 山东省济南市2023-2024学年高一上学期期末考试生物试题(解析版)
- 2025年工程春节停工期间安全措施
- 2024版人才引进住房租赁补贴协议3篇
- 川藏铁路勘察报告范文
- 新零售智慧零售门店解决方案
- 小学一年级数学20以内的口算题(可直接打印A4)
- 上海黄浦区2025届物理高一第一学期期末质量跟踪监视模拟试题含解析
- 肺结核课件教学课件
- 新生儿心脏病护理查房
- 规划设计行业数字化转型趋势
- 2024年广告代理合同的广告投放范围与分成比例
评论
0/150
提交评论