- 浏览: 438391 次
- 性别:
- 来自: 北京
-
文章分类
最新评论
-
springaop_springmvc:
apache lucene开源框架demo使用实例教程源代码下 ...
Java搜索工具——Lucene实例总结(一) -
chengang292214:
总结的不错
Web开发中的路径问题 -
liuyuanhui0301:
aka~
Java 归并排序(基于数组) -
IT人_:
不错
远程连接MySQL,防火墙阻止访问,解决办法 -
zhuchao_ko:
借鉴。
JNDI访问LDAP
工具函数的一般格式如下:$.函数名()或jQuery.函数名()
1. 浏览器检测
- 浏览器名称或版本信息
可通过$.browser对象获取浏览器信息
属性:
webkit 为true表示是webkit相关的浏览器
mozilla 为true表示是mozilla相关的浏览器
safari 为true表示safari相关的浏览器
opera 为true表示opera相关的浏览器
msic 为true表示IE浏览器
version 获取浏览器版本
例子:
if ($.browser.msie) { //IE浏览器 strTmp = "IE"; } if ($.browser.mozilla) { //火狐相关浏览器 strTmp = "Mozilla FireFox"; } trTmp = " 版本号是:"+ $.browser.version; //获取版本号
在Mozilla 浏览器中,$.browser.version显示的是内核版本,不是浏览器版本
- 盒子模型
盒子模型是CSS术语,用来描述页面设置中的各种属性,如内容(content),填充(padding),边框(border),边界(margin)
有两类盒子模型:W3C模型和IE盒子模型
W3C模型的属性height与Width取值不包含padding和border,仅仅指内容(content)的height与width
IE盒子模型的height与width属性值包含padding和border
$.support.boxModel返回一个布尔值,为true表示是W3C盒子模型,否则表示IE盒子模型
if ($.support.boxModel) { //是W3C盒子模型 strTmp += "W3C盒子模型"; }
2. 数组和对象操作
- 遍历数组
$.each()可以实现页面元素的遍历和指定数组的遍历
$.each(obj,fn(para1,para2)) obj表示要遍历的数组或对象
例子:
var arrStu = { "张三:": "60", "李四:": "70", "王二:": "80" } var strContent = "<li class='title'>姓名:分数</li>"; $.each(arrStu, function(Name, Value) { strContent += "<li>" + Name + Value + "</li>"; })
- 遍历对象
$.each($.ajaxSettings, function(Property, Value) { strContent += "<li>" + Property + ":" + Value + "</li>"; })
- 数据筛选
$.grep(array,function(elementOfArray,indexInArray),[event]) 根据条件筛选元素
array为要筛选的数组,elementOfArray为数组中的元素值,indexInArray为元素在数组中的序号,[event]为布尔值,表示是否根据fn的规则取反向结果。默认为false,表示不取反。
例子:查询素组中元素值大于5且序号小于8的元素
$(function() { var strTmp = "筛选前数据:"; var arrNum = [2, 8, 3, 7, 4, 9, 3, 10, 9, 7, 21]; var arrGet = $.grep(arrNum, function(ele, index) { return ele > 5 && index < 8 //元素值大于5且序号小于8 },【true】) strTmp += arrNum.join(); strTmp += "<br/><br>筛选后数据:" strTmp += arrGet.join(); $("#divTip").append(strTmp); })
- 数据变更
$.map(array,callback(elementOfArray,indexInArray))按指定条件修改数组中的所选元素
例子:将数组中元素值大于5且序号小于8的元素都增加3
$(function() { var strTmp = "变更前数据:"; var arrNum = [2, 8, 3, 7, 4, 9, 3, 10, 9, 7, 21]; var arrGet = $.map(arrNum, function(ele, index) { if (ele > 5 && index < 8){ //元素值大于5且序号小于8 return ele + 1; //元素增加1 } }) strTmp += arrNum.join(); strTmp += "<br/><br>变更后数据:" strTmp += arrGet.join(); $("#divTip").append(strTmp); })
- 数据搜索
$.inArray(value,array) 在数组中搜索某个元素,相当于javaScript中indexOf()搜索字符串中的某个字符。在$.inArray()中,如果找到了指定的某个元素,则返回该元素在数组中的索引号,否则返回-1。value表示搜索对象,array表示搜索数组。
例子:
$(function() { var strTmp = "待搜索数据:"; var arrNum = [4, 21, 2, 12, 5]; var arrPos = $.inArray(2, arrNum); strTmp += arrNum.join(); strTmp += "<br/><br>搜索后结果:" strTmp += arrPos; $("#divTip").append(strTmp); })
3. 字符串操作
- $.trim(str)删除字符串str中左右两边的空格符
- Startwith
- Endwith
4. 测试操作
- $.isArray(obj) 检测obj是否是数组对象
- $.isFunction(obj)检测obj是否是一个函数
- $.isEmptyObject(obj)检测obj是否是一个空对象
例子:
$(function() { var obj0 = {}; var obj1 = { "name": "taoguorong" }; var strTmp = "obj0是否为空:" + $.isEmptyObject(obj0);//true strTmp += "<br><br>obj1是否为空:" + $.isEmptyObject(obj1);//false $("#divTip").append(strTmp); })
- $.isPlainObject(obj)检测obj是否是一个原始对象
$(function() { var obj0 = {}; var obj1 = new Object(); var obj2 = "null"; var strTmp = "obj0是否为原始对象:" + $.isPlainObject(obj0);//true strTmp += "<br><br>obj1是否为原始对象:" + $.isPlainObject(obj1);//true strTmp += "<br><br>obj2是否为原始对象:" + $.isPlainObject(obj2);//false $("#divTip").append(strTmp); })
- $.contains(container,contained)检测一个dom节点是否包含另一个dom节点。
$(function() { var node0 = document.documentElement;//代表文档根节点 var node1 = document.body;//文档根节点下的子节点 var strTmp = "对象node0是否包含对象node1:" strTmp += $.contains(node0, node1);//检测两者的包含关系 返回true $("#divTip").append(strTmp); })
5. URL操作
$.param(obj,[traditional]) 按照name/value的格式对数组或jQuery对象进行序列化,obj是要序列化的数组或对象。
$(function() { var arrInfo = { id: 101, name: "tao", sex: 0 }; //基本信息数组 //分数和汇总信息数组 var arrScore = { Score: { chinese: 90, maths: 100, english: 98 }, SunNum: { Score: 288, Num: 3 } }; //序列化各数组 var arrNewInfo = $.param(arrInfo); var arrNewScore = $.param(arrScore); var arrDecScore = decodeURIComponent($.param(arrScore)); //显示序列化后的数组 var strTmp = "<b>arrInfo数组序列化后</b>:"; strTmp += arrNewInfo; strTmp += "<br><br><b>arrScore数组序列化后</b>:"; strTmp += arrNewScore; strTmp += "<br><br><b>arrScore序列化解码后</b>:"; strTmp += arrDecScore; //显示在页面中 $("#divTip").append(strTmp); })
6. 自定义工具类函数
$.extend()函数,可以编写自定义的工具函数
/*------------------------------------------------------------/ 功能:返回两个数中最大值 参数:数字p1,p2 返回:最大值的一个数 示例:$.MaxNum(1,2); /------------------------------------------------------------*/ ; (function($) { $.extend({ "MaxNum": function(p1, p2) { return (p1 > p2) ? p1 : p2; } }); })(jQuery); /*------------------------------------------------------------/ 功能:返回两个数中最小值 参数:数字p1,p2 返回:最小值的一个数 示例:$.MinNum(1,2); /------------------------------------------------------------*/ ; (function($) { $.extend({ "MinNum": function(p1, p2) { return (p1 > p2) ? p2 : p1; } }); })(jQuery); $(function() { var strTmp = "5与6中最大的数是:"; strTmp += $.MaxNum(5, 6); strTmp += "<br><br>7与8中最小的数是:"; strTmp += $.MinNum(7, ; $("#divTip").append(strTmp); })
$.extend()另外一个强悍的功能,就是可以扩展已有的Object对象:$.extend(target, object1,object2,…) 其中target表示合并后的对象,object表示被合并对象。
例:
var objName={name:“张三”,sex:”男”}; var objInfo={name:”李四”,age:30}; var objLast=$.extent(objName,objInfo); 结果:objLast={name:”李四”,sex:”男”,age:”30”}
可以看出,$.extend()函数在合并对象时,相同的参数名称,后面对象会覆盖前面对象的参数值。
7. $.proxy()处理不同作用域对象事件
$.proxy(function,scope)
$.proxy(scope,name)
$.proxy()返回一个新的函数,这个函数始终保持特定的作用域。当一个事件函数被元素绑定时,其作用域原则上应指向该元素。参数scope为被事件函数设定的作用域对象
例子:
$(function() { var objMyInfo = { name: "陶国荣", //设置对象name属性 sex: "男", //设置对象sex属性 ShowEvent: function() { //设置执行的事件 $("#divShow").html("姓名:" + this.name + "<br><br>性别:" + this.sex); } } $("#Button1").bind("click", $.proxy(objMyInfo, "ShowEvent"));//通过proxy函数绑定设置的事件 })
$("#Button1").bind("click", $.proxy(objMyInfo, "ShowEvent"));与
$("#Button1").bind("click",objMyInfo.ShowEvent);的区别是,后者传递的this作用域与事件函数中的this的作用域不同,因此,无法访问事件函数中的name与sex属性。而前者指定作用域是objMyInfo,即,代表事件中this的作用域。前者等价于$("#Button1").bind("click", $.proxy(objMyInfo.ShowEvent, objMyInfo));
8. 正则表达式字符串类型检验
发表评论
-
How tomcat works
2011-10-30 10:01 11011. Tomcat 模型:connector--------- ... -
jQuery Cookie插件
2011-10-06 10:49 0back>> cookie插件可以很 ... -
jQuery form表单插件
2011-10-06 10:45 1039back>> http://www.cnbl ... -
jQuery验证插件
2011-10-06 10:40 1428back>> 使用示例: <!DOCTY ... -
jQuery性能优化
2011-10-06 10:28 1722back>> 1. 优化选择器的执行速度 ... -
ajax在jQuery中的应用
2011-10-06 09:50 1833back>> 1. 加载异步数据 ... -
jQuery动画与特效
2011-10-05 15:26 2263back>> 1. 显示与隐 ... -
jQuery事件
2011-10-05 15:08 2670back>> 1. 事件机制 ... -
Jquery Dom操作
2011-10-05 14:44 1672back>> 1. 元素属性操作 ... -
jQuery选择器
2011-10-05 09:04 2762back>> 1. 表格各 ... -
jQuery权威指南
2011-10-05 08:58 857jQuery权威指南 1. jQuery入门 2. ... -
Jquery入门
2011-09-28 14:41 12031. Jquery基本功能 * 访问和操作D ... -
comet pushlet
2011-08-12 17:49 21911.http://www.ibm.com/developerw ... -
Ajax开发
2011-07-25 21:50 16221. netbeans 中文版改成英文版 在NetBea ... -
CSS+DIV
2011-06-28 16:02 1180精通CSS+DIV网页样式与布局 曾顺 人民邮电出 ... -
jquery
2011-06-09 08:08 1019http://www.css888.com/ jQuer ... -
jsp乱码解决大全(转自csdn一高手)
2011-03-04 17:01 2252好文章, ... -
Unicode 控制字符
2011-03-03 11:44 3216<li> : &am ... -
URL中汉字乱码问题
2011-02-26 12:01 1619返回 Oak>> 服务器 ... -
分 页
2011-02-23 18:27 869返回Oak>> 1. 几种不同的分 ...
相关推荐
OpenGL是一种强大的图形库,用于创建2D和3D图形,广泛应用于游戏开发、科学可视化、工程设计等领域。在这个项目中,我们看到一个基于OpenGL的机械臂运动仿真程序,它能够实现机械臂在四个方向上的旋转。这样的模拟对于理解机械臂的工作原理、机器人控制算法以及进行虚拟环境中的机械臂运动测试具有重要意义。 我们需要了解OpenGL的基础知识。OpenGL是一个跨语言、跨平台的编程接口,用于渲染2D和3D矢量图形。它提供了大量的函数来处理图形的绘制,包括几何形状的定义、颜色设置、光照处理、纹理映射等。开发者通过OpenGL库调用这些函数,构建出复杂的图形场景。 在这个机械臂仿真程序中,C#被用来作为编程语言。C#通常与Windows平台上的.NET Framework配合使用,提供了一种面向对象的、类型安全的语言,支持现代编程特性如LINQ、异步编程等。结合OpenGL,C#可以构建高性能的图形应用。 机械臂的运动仿真涉及到几个关键的计算和控制概念: 1. **关节角度**:机械臂的每个部分(或关节)都有一个或多个自由度,表示为关节角度。这些角度决定了机械臂各部分的位置和方向。 2. **正向运动学**:根据关节角度计算机械臂末端执行器(如抓手)在空间中的位置和方向。这涉及将各个关节的角度转换为欧拉角或四元数,然后转化为笛卡尔坐标系的X、Y、Z位置和旋转。 3. **反向运动学**:给定末端执行器的目标位置和方向,计算出各关节所需的理想角度。这是一个逆向问题,通常需要解决非线性方程组。 4. **运动规划**:确定从当前状态到目标状态的路径,确保机械臂在运动过程中避免碰撞和其他约束。 5. **OpenGL的使用**:在OpenGL中,我们首先创建几何模型来表示机械臂的各个部分。然后,使用矩阵变换(如旋转、平移和缩放)来更新关节角度对模型的影响。这些变换组合起来,形成机械臂的动态运动。 6. **四向旋转**:机械臂可能有四个独立的旋转轴,允许它在X、Y、Z三个轴上旋转,以及额外的绕自身轴线的旋转。每个轴的旋转都由对应的关节角度控制。 7. **交互控制**:用户可能可以通过输入设备(如鼠标或键盘)调整关节角度,实时观察机械臂的运动。这需要将用户输入转换为关节角度,并应用到运动学模型中。 8. **图形渲染**:OpenGL提供了多种渲染技术,如深度测试、光照模型、纹理映射等,可以用于提高机械臂模拟的真实感。例如,可以添加材质和纹理来模拟金属表面,或者使用光照来增强立体感。 这个项目结合了OpenGL的图形渲染能力与C#的编程灵活性,构建了一个可以直观展示机械臂运动的仿真环境。通过理解并实现这些关键概念,开发者不仅能够学习到图形编程技巧,还能深入理解机器人学的基本原理。
android11 udpate-engine 系统升级模块源码下载
内容概要:本文详细介绍了如何在MATLAB环境中实现SVM二分类算法,涵盖数据预处理、参数寻优及结果可视化的全过程。首先进行数据归一化处理,确保各特征在同一量纲下参与模型训练。接着采用网格搜索法对SVM的关键参数c(惩罚系数)和g(核参数)进行自动化寻优,利用5折交叉验证评估每组参数的表现。最后通过等高线图和3D曲面图直观展示参数与准确率之间的关系,并完成最终模型的训练与预测。 适合人群:具有一定MATLAB编程基础的研究人员和技术爱好者,尤其是从事机器学习、数据分析领域的从业者。 使用场景及目标:适用于需要快速搭建SVM二分类模型并进行参数调优的项目。主要目标是在短时间内获得较高准确度的分类结果,同时掌握SVM的工作原理及其在MATLAB中的具体应用方法。 其他说明:文中提供了完整的代码示例,便于读者直接上手实践。此外还提到了一些常见的注意事项,如数据格式要求、类别不平衡处理以及特征工程的重要性等。
ffmpeg
江科大CAN入门教程,万字长文理解
内容概要:本文详细介绍了基于新唐N79E814单片机的移动电源设计方案,涵盖硬件架构、PCB原理图、电路设计、代码实现等方面。移动电源主要由电池、充电电路和输出电路构成,文中重点讲解了5V1A和5V2.1A两路输出的设计思路,包括同步整流、PWM控制、充电管理等关键技术。同时,文章还探讨了PCB布局、烧录注意事项、效率优化等内容,并提供了具体的代码示例和调试建议。 适合人群:具有一定电子技术和单片机开发基础的工程师和技术爱好者。 使用场景及目标:适用于希望深入了解移动电源设计原理和实现方法的人群,旨在帮助读者掌握从原理图绘制到实际产品制作的全过程,提升电路设计和调试能力。 其他说明:文章不仅提供了理论知识,还包括大量实践经验分享,如常见的调试陷阱和解决方法,有助于读者在实践中少走弯路。
动漫角色分割_基于深度学习实现的高精度动漫角色分割算法_附项目源码_优质项目实战
javacv实现的支持多种音视频播放的播放器,比如MP4、avi、mkv、flv、MP3、ogg、wav、au等多种音视频格式,非常好用。
开发调试demo,简单的自动登录功能,插件开发入门参考
内容概要:本文详细介绍了通过修改Windows注册表来启用和配置被禁用的用户账户(如WDAGUtilityAccount)的过程。首先,通过计算机管理界面查看被禁用的用户账户,并进入注册表编辑器定位到HKEY_LOCAL_MACHINE\SAM\SAM\Domains\Account\Users路径下的相应用户条目。接着,通过对特定用户的二进制数据进行编辑,包括复制和修改关键字段,实现对被禁用账户的克隆与重新启用。最后,验证账户状态的变化,并通过远程桌面连接测试新配置的有效性。 适合人群:具备一定Windows系统管理基础的技术人员,尤其是负责企业内部网络和用户账户管理的IT管理员。 使用场景及目标:①当需要恢复或重新配置被禁用的用户账户时;②在进行系统故障排除或安全审计时,了解如何通过注册表直接操作用户账户;③确保特定用户能够正常登录并访问远程桌面服务。 阅读建议:本文涉及较为底层的系统操作,建议读者在实际操作前充分备份系统和注册表,避免误操作导致系统不稳定。同时,对于不熟悉注册表编辑的用户,应先在测试环境中练习,确保掌握相关技能后再应用于生产环境。此外,建议结合官方文档或其他权威资料,加深对Windows用户账户管理机制的理解。
2025免费微信小程序毕业设计成品,包括源码+数据库+往届论文资料,附带启动教程和安装包。 启动教程:https://www.bilibili.com/video/BV1BfB2YYEnS 讲解视频:https://www.bilibili.com/video/BV1BVKMeZEYr 技术栈:Uniapp+Vue.js+SpringBoot+MySQL。 开发工具:Idea+VSCode+微信开发者工具。
内容概要:本文详细介绍了基于西门子S7-1200 PLC的两部六层电梯控制系统的设计与实现。主要内容涵盖前期准备工作,如选择合适的PLC型号和配置硬件;核心逻辑部分深入讲解了梯形图编程的具体实现方法,包括楼层呼叫逻辑、电梯运行方向控制以及两部电梯之间的协同工作;此外,文章还探讨了仿真测试的方法及其重要性,提供了许多实用技巧和注意事项。通过具体实例展示了如何利用博途V15软件进行电梯系统的开发,并分享了一些实际操作中的经验和常见问题解决方案。 适合人群:从事工业自动化领域的工程师和技术人员,特别是那些对PLC编程有兴趣或者正在参与类似项目的从业者。 使用场景及目标:适用于需要理解和掌握S7-1200 PLC编程技能的人群,尤其是希望通过实际案例加深对梯形图编程理解的学习者。目标是在实践中提高编程能力,能够独立完成类似的工程项目。 其他说明:文中不仅包含了详细的理论解释,还有丰富的代码片段供读者参考。对于初学者而言,建议先从单部电梯开始练习,逐步过渡到复杂的双梯联调。同时,作者强调了仿真测试的重要性,指出这是验证程序正确性和优化性能的关键步骤。
2025免费微信小程序毕业设计成品,包括源码+数据库+往届论文资料,附带启动教程和安装包。 启动教程:https://www.bilibili.com/video/BV1BfB2YYEnS 讲解视频:https://www.bilibili.com/video/BV1BVKMeZEYr 技术栈:Uniapp+Vue.js+SpringBoot+MySQL。 开发工具:Idea+VSCode+微信开发者工具。
内容概要:该资源为大学英语四级听力练习音频 MP3,包含丰富多样的听力素材。涵盖四级考试常见的各类场景,如校园生活(课程学习、社团活动等)、日常社交(聚会、聊天等)、工作求职(面试、职场事务等)、旅行交通(出行方式、景点介绍等)、饮食健康(餐厅点餐、健康养生等)。音频内容依照四级听力考试题型和难度精心录制,有短对话、长对话、短文听力等形式,且语速、口音等符合四级考试要求,助力考生熟悉考试形式与节奏。 适合人群:正在备考大学英语四级考试,希望提升听力水平的学生;英语基础中等,需要通过针对性练习来适应四级听力难度、提升听力理解能力的学习者;对英语听力学习有需求,想通过大量练习积累场景词汇、熟悉英语表达习惯的人群。 能学到什么:①熟悉四级听力考试的各类场景词汇,增强词汇储备并提升在听力语境中的反应速度;②掌握不同场景下的英语常用表达和句式,提升英语语言运用能力;③锻炼听力理解技巧,如抓取关键词、推断隐含意思、梳理篇章逻辑等;④适应四级听力考试的语速、口音和题型设置,增强应试能力和自信心。 阅读建议:制定系统的练习计划,定期定量进行听力练习,如每天安排 30 - 60 分钟;第一遍泛听,了解大致内容和主题;第二遍精听,逐句听写或分析不懂的词汇和句子;对照听力原文,明确错误和没听懂的地方,积累生词和表达;定期进行模拟测试,利用该音频模拟考试环境,检验学习效果并调整学习策略。
2000-2017年各省天然气消费量数据 1、时间:2000-2017年 2、来源:国家统计j、能源nj 3、指标:行政区划代码、城市、年份、天然气消费量 4、范围:31省
内容概要:本文详细介绍了基于西门子PLC1200的自动化控制系统,涵盖了PLC与库卡机器人通过Profinet通讯、PTO模式控制松下伺服、36路模拟量处理(包括压力检测、位置检测及压力输出)、以及26个温控器通过485总线通讯的关键技术和实现方法。此外,还包括了昆仑通态触摸屏的人机交互界面设计,提供了详细的硬件组态、软件编程指导和设备操作说明。 适合人群:从事工业自动化领域的工程师和技术人员,尤其是那些负责多设备协同控制项目的设计和实施的专业人士。 使用场景及目标:适用于需要整合多种设备(如PLC、机器人、伺服系统、温控器等)的复杂自动化生产线。主要目标是提高生产效率、增强系统的稳定性和可靠性,同时降低维护成本。 其他说明:文中不仅提供了具体的编程实例和硬件配置指南,还分享了许多实际调试过程中积累的经验教训,有助于读者在实际应用中少走弯路。
内容概要:本文深入探讨了AUTOSAR BSW(Basic Software)层所提供的各类服务、驱动、接口和管理器模块及其功能。BSW提供的服务包括I/O、Memory、Crypto、Communication、Off-board Communication和System等,涵盖了标准化的访问方式以确保不同硬件和系统的兼容性与安全性。BSW里的驱动分为内部驱动和外部驱动,分别用于控制和访问微控制器内部和外部的设备,确保硬件功能的正常运作。BSW里的接口(xx_IF)对下层模块进行抽象和封装,提供标准API接口,使上层应用无需关注底层硬件细节。BSW里的管理器(xxxM)则为多个客户端提供特定服务,能够修改或适配调整一些数据,以满足复杂需求。此外,文中还简要介绍了AUTOSAR里的库文件,它们是无状态的函数集合,可被多个模块调用以实现特定功能。 适合人群:对汽车电子软件架构有一定了解,尤其是对AUTOSAR标准感兴趣的工程师和技术人员。 使用场景及目标:①理解BSW层提供的各类服务及其应用场景;②掌握BSW中驱动、接口和管理器模块的设计原理和功能;③了解库文件的作用及其在AUTOSAR架构中的位置。 其他说明:本文详细解释了BSW层各组件的功能和作用,帮助读者更好地理解AUTOSAR架构的设计思想和实现方法。建议读者结合实际项目经验,深入研究各模块的具体实现和应用场景。
内容概要:本文介绍了西门子1200系列PLC的伺服步进FB块程序,该程序由两个FB块组成,分别采用SCL语言和梯形图编写,支持PTO和PN模式,适用于多种伺服系统和步进电机。程序经过实际调试,稳定性高,兼容性强,能够灵活应用于单轴或多轴控制系统。文中提供了详细的代码示例和调试指南,帮助用户快速上手并解决常见问题。 适合人群:从事工业自动化控制领域的工程师和技术人员,尤其是使用西门子1200系列PLC进行项目开发的人员。 使用场景及目标:①用于单轴或多轴伺服步进系统的控制;②提高项目的开发效率和稳定性;③减少重复开发的工作量,加快项目进度。 其他说明:程序需要在TIA V14及以上版本打开,附带详细的文档说明和实际项目视频链接,方便用户理解和使用。
基于SpringBoot+Vue的电子招投标系统源码+数据库.zip 高分通过项目,已获导师指导。 本项目是一套基于Springboot的电子招投标系统,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的Java学习者。也可作为课程设计、期末大作业 包含:项目源码、数据库脚本、开发说明文档、演示视频等,该项目可以直接作为毕设使用。 项目都经过严格调试,确保可以运行! 基于SpringBoot+Vue的电子招投标系统源码+数据库.zip 高分通过项目,已获导师指导。 本项目是一套基于Springboot的电子招投标系统,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的Java学习者。也可作为课程设计、期末大作业 包含:项目源码、数据库脚本、开发说明文档、演示视频等,该项目可以直接作为毕设使用。 项目都经过严格调试,确保可以运行! 基于SpringBoot+Vue的电子招投标系统源码+数据库.zip 高分通过项目,已获导师指导。 本项目是一套基于Springboot的电子招投标系统,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的Java学习者。也可
金秋风影桂林山水卡通儿童教学课件模板.pptx