当前位置: 首页 > 编程日记 > 正文

前端Js框架 UI框架汇总 特性 适用范围 选择

身为一个资深后端工程师,面对层出不穷的前端框架,总让人眼花缭乱,做一个综合解析贴,从全局着眼,让我们明白各种前端框架的应用范围,为如何选择前端框架,从不同的维度提供一些线索,做为一个长期优化贴,欢迎指正留言讨论。(注:排名不分先后,好像也没有排名)

◆ BootStrap 1.0 2.0 3.0

分类:UI框架

适用范围:优化布局 美化页面 现成组件

使用方式:组件 class

框架愿景:

组成:

特点:

说明:最早的前端框架,好像没有之一,笔者只用过它的组件(1.0)现在已经发展到4.0 真的不知道现在是什么特性,所以按最初的印象, 能用来美化页面 优化布局 使用一些现成组件

◆ LayUI

分类:UI框架

适用范围:优化布局 美化页面 现成组件

使用方式:组件 class

框架愿景: 源引官网 我们都在有意或无意地追逐。而 layui 偏偏回望当初,奔赴在返璞归真的漫漫征途,自信并勇敢着,追寻于原生态的书写指令,试图以最简单的方式诠释高效。

组成:

特点:

说明:新出现的一个UI类框架,在Js框架大行其道UI框架越来越少的情况下,新出现做UI框架真的需要勇气,而笔者也正是因为对BootStrap审美疲劳而寻找新的框架,所以笔者很支持,其它了解不多。

◆ AmazeUI-妹子UI

分类:UI框架

适用范围:优化布局 美化页面 现成组件

使用方式:组件 class

框架愿景:为移动而生

组成:

特点:

说明:

◆ EasyUI

分类:UI框架

适用范围:优化布局 美化页面 现成组件

使用方式:组件 class

框架愿景:

组成:

特点:

说明:

◆ Vue.js

分类:UI框架

适用范围:优化布局 美化页面 现成组件

使用方式:组件 class

框架愿景:

组成:

特点:

说明:

◆ Node.Js

分类:UI框架

适用范围:优化布局 美化页面 现成组件

使用方式:组件 class

框架愿景:

组成:

特点:

说明:应该是JS框架的开山笔祖,或是将前端框架推向繁荣的中流砥柱,成功的将"前端"推向"后端", 原来只在V层(MVC)活动的前端,终于扩展到了其它层

1.BootStrap 1.0 2.0 3.0

分类:UI框架

适用范围:优化布局 美化页面 现成组件

使用方式:组件 class

框架愿景:

组成:

特点:

说明:最早的前端框架,好像没有之一,笔者只用过它的组件(1.0)现在已经发展到4.0 真的不知道现在是什么特性,所以按最初的印象, 能用来美化页面 优化布局 使用一些现成组件

1.BootStrap 1.0 2.0 3.0

分类:UI框架

适用范围:优化布局 美化页面 现成组件

使用方式:组件 class

框架愿景:

组成:

特点:

说明:最早的前端框架,好像没有之一,笔者只用过它的组件(1.0)现在已经发展到4.0 真的不知道现在是什么特性,所以按最初的印象, 能用来美化页面 优化布局 使用一些现成组件

前端Js框架汇总

概述:

有些日子没有正襟危坐写博客了,互联网飞速发展的时代,技术更新迭代的速度也在加快。看着Java、Js、Swift在各领域心花路放,也是煞是羡慕。寻了寻.net的消息,也是振奋人心,.net core 1,mono,xamarin等等,但大多都还在狂吼的阶段。其实一直以来对技术的理解是技术服务于业务和产品,产品又在不同程度的推进着技术的演进。

Web、无线、物联网、VR、PC从不同方向推进着技术的融合与微创新。程序员在不同业务场景下的角色互换。而随着node.js的出现语言的角色也在发生着转变,Js扮演了越来越重要的角色。也就有了茶余饭后也把了解到的知识整理一下。看过“你的知识需要管理”后,强烈的意识到杂乱且范范的知识储备远不如整理后条理清晰的知识带来好处多。所以,是的,我们需要时不时的回来对掌握的知识梳理归类,以备不时之需。

一、前端框架库:

1.Zepto.js

  • 地址:http://www.css88.com/doc/zeptojs/
  • 描述:Zepto是一个轻量级的针对现代高级浏览器的JavaScript库, 它与jquery有着类似的api。 如果你会用jquery,那么你也会用zepto。关于Zepto认知我也是通过与一位腾讯朋友聊天的时候知道的,只作了些基础的了解。

2.SUI Mobile

  • 地址:http://m.sui.taobao.org
  • 描述:SUI Mobile 是一套基于 Framework7 开发的UI库。它非常轻量、精美,只需要引入我们的CDN文件就可以使用,并且能兼容到 iOS 6.0+ 和 Android 4.0+,非常适合开发跨平台Web App。
  • 用途:你也看到了,他是用于无线端的Web App的开发。

3.Node.Js

  • 地址:http://www.runoob.com/nodejs/nodejs-tutorial.html (中文网)
  • 描述:Node.js是一个Javascript运行环境(runtime)。实际上它是对Google V8引擎进行了封装。V8引 擎执行Javascript的速度非常快,性能非常好。Node.js对一些特殊用例进行了优化,提供了替代的API,使得V8在非浏览器环境下运行得更好。
Node.js是一个基于Chrome JavaScript运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞I/O 模型而得以轻量和高效,非常适合在分布式设备上运行数据密集型的实时应用。

简单的说 Node.js 就是运行在服务端的 JavaScript。

Node.js 是一个基于Chrome JavaScript 运行时建立的一个平台。

Node.js是一个事件驱动I/O服务端JavaScript环境,基于Google的V8引擎,V8引擎执行Javascript的速度非常快,性能非常好。

  • 用途:

1. RESTful API

这是NodeJS最理想的应用场景,可以处理数万条连接,本身没有太多的逻辑,只需要请求API,组织数据进行返回即可。它本质上只是从某个数据库中查找一些值并将它们组成一个响应。由于响应是少量文本,入站请求也是少量的文本,因此流量不高,一台机器甚至也可以处理最繁忙的公司的API需求。

2. 统一Web应用的UI层

目前MVC的架构,在某种意义上来说,Web开发有两个UI层,一个是在浏览器里面我们最终看到的,另一个在server端,负责生成和拼接页面。

不讨论这种架构是好是坏,但是有另外一种实践,面向服务的架构,更好的做前后端的依赖分离。如果所有的关键业务逻辑都封装成REST调用,就意味着在上层只需要考虑如何用这些REST接口构建具体的应用。那些后端程序员们根本不操心具体数据是如何从一个页面传递到另一个页面的,他们也不用管用户数据更新是通过Ajax异步获取的还是通过刷新页面。

3. 大量Ajax请求的应用

例如个性化应用,每个用户看到的页面都不一样,缓存失效,需要在页面加载的时候发起Ajax请求,NodeJS能响应大量的并发请求。  总而言之,NodeJS适合运用在高并发、I/O密集、少量业务逻辑的场景。

4.angular.Js

  • 地址:http://www.runoob.com/angularjs/angularjs-tutorial.html (中文网)
  • 描述:AngularJS[1]  诞生于2009年,由Misko Hevery 等人创建,后为Google所收购。是一款优秀的前端JS框架,已经被用于Google的多款产品当中。AngularJS有着诸多特性,最为核心的是:MVVM、模块化、自动化双向数据绑定、语义化标签、依赖注入等等。
  • 用途:通过描述我们应该就能很好的明白AngularJS的真实用途了,MVVM,模块化,自动化双向数据绑定等等。除了简单的dom操作外,更能体现Js编程的强大。当然应用应该视场合而定。

5.JQuery Mobile

  • 地址:http://www.w3school.com.cn/jquerymobile/    (中文网)
  • 描述:Query Mobile是jQuery 在手机上和平板设备上的版本。jQuery Mobile 不仅会给主流移动平台带来jQuery核心库,而且会发布一个完整统一的jQuery移动UI框架。支持全球主流的移动平台。jQuery Mobile开发团队说:能开发这个项目,我们非常兴奋。移动Web太需要一个跨浏览器的框架,让开发人员开发出真正的移动Web网站。
  • 用途:jQuery Mobile 是创建移动 web 应用程序的框架。

jQuery Mobile 适用于所有流行的智能手机和平板电脑。

jQuery Mobile 使用 HTML5 和 CSS3 通过尽可能少的脚本对页面进行布局。

6.requirejs

  • 地址:http://www.requirejs.cn/
  • 描述:RequireJS的目标是鼓励代码的模块化,它使用了不同于传统<script>标签的脚本加载步骤。可以用它来加速、优化代码,但其主要目的还是为了代码的模块化。它鼓励在使用脚本时以module ID替代URL地址。

RequireJS以一个相对于baseUrl的地址来加载所有的代码。 页面顶层<script>标签含有一个特殊的属性data-main,require.js使用它来启动脚本加载过程,而baseUrl一般设置到与该属性相一致的目录。

  • 用途:模块化动态加载。

7.Vue.js

  • 地址:http://cn.vuejs.org/
  • 描述:Vue.js 是用于构建交互式的 Web  界面的库。它提供了 MVVM 数据绑定和一个可组合的组件系统,具有简单、灵活的 API。从技术上讲, Vue.js 集中在 MVVM 模式上的视图模型层,并通过双向数据绑定连接视图和模型。实际的 DOM 操作和输出格式被抽象出来成指令和过滤器。相比其它的 MVVM 框架,Vue.js 更容易上手。

8.backbone.js

  • 地址:http://www.css88.com/doc/backbone/
  • 描述:Backbone 为复杂Javascript应用程序提供模型(models)、集合(collections)、视图(views)的结构。其中模型用于绑定键值数据和自定义事件;集合附有可枚举函数的丰富API; 视图可以声明事件处理函数,并通过RESTful JSON接口连接到应用程序。

9.React

  • 地址:http://reactjs.cn/react/docs/why-react.html
  • 描述:React 是一个 Facebook 和 Instagram 用来创建用户界面的 JavaScript 库。很多人认为 React 是 MVC 中的 V(视图)。我们创造 React 是为了解决一个问题:构建随着时间数据不断变化的大规模应用程序。为了达到这个目标,React 采用下面两个主要的思想。

10.Ionic

  • 地址:http://www.ionic.wang/js_doc-index.html
  • 描述:Ionic既是一个CSS框架也是一个Javascript UI库。许多组件需要Javascript才能产生神奇的效果,尽管通常组件不需要编码,通过框架扩展可以很容易地使用,比如我们的AngularIonic扩展。

    Ionic遵循视图控制模式,通俗的理解和 Cocoa 触摸框架相似。在视图控制模式中,我们将界面的不同部分分为子视图或包含其他视图的子视图控制器。然后视图控制器“驱动”内部视图来提供交互和UI功能。一个很好的例子就是标签栏(Tab Bar)视图控制器处理点击标签栏在一系列可视化面板间切换。

    浏览我们的API文档来了解视图控制器和Ionic中可用的Javascript实用工具。

    Ionic 是目前最有潜力的一款 HTML5 手机应用开发框架。通过 SASS 构建应用程序,它 提供了很多 UI 组件来帮助开发者开发强大的应用。 它使用 JavaScript MVVM 框架和 AngularJS 来增强应用。提供数据的双向绑定,使用它成为 Web 和移动开发者的共同选择。

二、前端UI框架

1.Pure

  • 地址:http://purecss.org/layouts/
  • 描述:Pure精心设计,只为可以在任何Web项目中使用。为了例证这一点,我们制作了如下几个模板。这些模板都是响应式的,并且没有使用任何JavaScript。
  • 用途:真的是很精美的一个样式框架,便于我们快事构建一些个人产品,当然也可以服务于工作中的一些项目。

2.bootstrap

  • 地址:http://www.bootcss.com/
  • 描述:简洁、直观、强悍的前端开发框架,让web开发更迅速、简单。

3.EasyUI

  • 地址:http://www.jeasyui.net/  (中文网)
  • 描述:easyui是一种基于jQuery的用户界面插件集合。

easyui为创建现代化,互动,JavaScript应用程序,提供必要的功能。

使用easyui你不需要写很多代码,你只需要通过编写一些简单HTML标记,就可以定义用户界面。

easyui是个完美支持HTML5网页的完整框架。

easyui节省您网页开发的时间和规模。

easyui很简单但功能强大的。

4.Ant Design

  • 地址:http://ant.design/
  • 描述:一个 UI 设计语言,一套提炼和应用于企业级后台产品的交互语言和视觉体系

三、可视化组件

1.Echarts

  • 地址:http://echarts.baidu.com/
  • 描述:ECharts,一个纯 Javascript 的图表库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(IE8/9/10/11,Chrome,Firefox,Safari等),底层依赖轻量级的 Canvas 类库ZRender,提供直观,生动,可交互,可高度个性化定制的数据可视化图表。

2.tableau(收费)

  • 地址:http://www.yuandingit.com/special/tableau/index.html
  • 描述:Tableau 是桌面系统中最简单的商业智能工具软件,Tableau 没有强迫用户编写自定义代码,新的控制台也可完全自定义配置。在控制台上,不仅能够监测信息,而且还提供完整的分析能力。Tableau控制台灵活,具有高度的动态性。

四、前端构建工具

1.gulp

  • 地址:http://www.gulpjs.com.cn/
  • 描述易于使用
通过代码优于配置的策略,Gulp 让简单的任务简单,复杂的任务可管理。

构建快速

利用 Node.js 流的威力,你可以快速构建项目并减少频繁的 IO 操作。

插件高质

Gulp 严格的插件指南确保插件如你期望的那样简洁高质得工作。

易于学习

通过最少的 API,掌握 Gulp 毫不费力,构建工作尽在掌握:如同一系列流管道。

EasyUI/Bootstrap/Amaze UI/Foundation/Semantic UI/Pure/UIkit/

Angular/Vue.js/React.js/Ember.js

相关文章:

Emptyproject分析

Emptyproject分析(SimpleSample)1&#xff0c;InitApp()WinMain中有一个InitApp()&#xff0c;在sample中存在&#xff0c;但是在emptyproject中没有&#xff0c;该函数是用于设定已经声明的一些一般变量的初始值的。比如某些按钮。2&#xff0c;IsDeviceAcceptable()被WinMain…

1107 Social Clusters

这道题目给出的示例如上图所示&#xff0c;一共有1-8这8个人(圆形)&#xff0c;他们拥有1-10这10个兴趣爱好(方形)&#xff0c;一人可以有多个爱好&#xff0c;拥有共同爱好的人被视为一个社区的。现在给出每个人的爱好情况&#xff0c;求出社区的个数&#xff0c;并按照从大到…

c#直接调用ssis包实现Sql Server的数据导入功能

调用ssis包实现Sql Server的数据导入功能网上已经有很多人讨论过&#xff0c;自己参考后也动手实现了一下&#xff0c;上一次笔者的项目中还用了一下这个功能。思前想后&#xff0c;决定还是贴一下增强记忆&#xff0c;高手请54.1、直接调用ssis包&#xff0c;需要引用Microsof…

从入门到放弃的javaScrip——队列

队列数据结构 队列是遵循FIFO&#xff08;First In First Out&#xff0c;先进先出&#xff0c;也称为先来先服务&#xff09;原则的一组有序的项。队列在尾部添加新元素&#xff0c;并从顶部移除元素。最新添加的元素必须排在队列的末尾。 现实中&#xff0c;很常见的例子就是…

css控制不换行

white-space:nowrap; 转载于:https://www.cnblogs.com/w8104254/p/4178198.html

(C++)堆排序的3个关键函数

堆排序&#xff1a;指使用堆结构对一个序列进行排序。所以&#xff0c;首先要有一个堆结构。 此处讨论递增排序。以及用最大堆。 注意&#xff1a;让存放堆的数组作为全局变量&#xff0c;n为元素个数&#xff0c;数组存放元素从下标1开始&#xff0c;n结束。 int heap[11] …

android 横竖屏限制如何配置

在开发android的应用中&#xff0c;有时候需要限制横竖屏切换。只需要在AndroidManifest.xml文件中加入android:screenOrientation属性限制。 ndroid:screenOrientation"landscape"是限制此页面横屏显示&#xff0c; ndroid:screenOrientation"portrait"是…

Java面试题总结-Day4

<?xml version"1.0" encoding"utf-8"?> Java面试题总结-Day4Java面试题总结-Day4 Table of Contents 1. ArrayList和LinkedList区别 1.1. 是否线程安全1.2. 底层数据结构1.3. 插入和删除是否受元素位置的影响1.4. 是否支持快速随机访问1.5. 内存空…

Linux 使用者身份與群組記錄的檔案

在我們Linux系統當中&#xff0c;預設的情況下&#xff0c;所有的系統上的帳號與一般身份使用者&#xff0c;還有那個root的相關資訊&#xff0c; 都是記錄在/etc/passwd這個檔案內的。至於個人的密碼則是記錄在/etc/shadow這個檔案下。 此外&#xff0c;Linux所有的群組名稱都…

1098 Insertion or Heap Sort 需再做

1. 应该还做过一道类似的题目&#xff0c;也是要求判断属于哪种排序的中间过程&#xff0c;并要求写出下一轮排序结果&#xff0c;这次的进步是上来就知道用向量存数据&#xff0c;这样方便直接比较&#xff0c;而且下标0不能存元素&#xff0c;因为堆排序的堆是一个完全二叉树…

基于node.js的压缩合并安装

1.构建工具&#xff08;grunt,gulp&#xff09; 下载地址&#xff1a;http://gruntjs.cn/http://gruntjs.com/&#xff08;1&#xff09;安装nodejs(http://www.nodejs.org/) 验证是否安装成功&#xff0c;命令行输入 node -v &#xff08;2&#xff09;grunt 的安装 安装全局…

jenkins 修改工作目录

修改Jenkins路径 Jenkins的默认安装路径是/var/lib/jenkins 现在由于这个根目录的磁盘太小&#xff0c;所以切换到/data 目录下。 Jenkins目录、端口、工作目录等信息在/etc/sysconfig/jenkins 下&#xff0c;所以需要修改这个文件。 将JENKINS_HOME"/var/lib/jenkins&quo…

破一个行业ERP的感想

今天闲来无事&#xff0c;找来破一破。 这个是一个行业性质的ERP软件&#xff0c;有授权码验证&#xff0c;客户机数量限定&#xff0c;以及使用时间限定&#xff0c;被一一破解。 授权码存在明显的绕过bug.客户机数量同样被明文标注在文件中。使用时间也是标注在文件中&#x…

1034 Head of a Gang(图的DFS解法) 擦边大法好

1.题目的大意是给出很多人(结点)之间的通话记录&#xff0c;每两人之间的权重取决于他俩通话权重的总时长&#xff0c;如果一个社区的人数超过2且社区内发生的通话总时长超过给定阈值&#xff0c;那么这属于一个社区。最后要求输出社区的总数&#xff0c;再按照社区头目的姓名字…

Android定位方式和测试方法

Android常用的三种定位方式有&#xff1a;基于GPS定位、基于基站地位、基于wifi定位。 1、基于GPS定位&#xff1a; GPS定位需要GPS模块(硬件)的支持,没有GPS模块是无法进行GPS定位的。 GPS定位最大的优点就是其定位精确度高(一般误差在10m内),无网络也能用;缺点就是耗电高、定…

vue el-form鼠标事件导致页面刷新解决方案;vue 阻止多次点击提交数据通用方法...

一.阻止表单自动提交刷新页面&#xff1a;<el-form><el-form-item :inline"true" submit.native.prevent><el-input keyup.enter.nativesubmit></el-input></el-form-item> </el-form>注意&#xff1a; 鼠标事件导致页面刷新问…

[转]wxODBC(wxWidgets)中使用驱动程序方式打开数据库

wxODBC(wxWidgets)中使用驱动程序方式打开数据库 wxWidgets的文档中都是使用在控制面板/数据源中设定DSN来创建ODBC连接。但是实际上很多小型的应用&#xff0c;只是使用本机的一个Access数据库。而要求使用者学习ODBC的DSN配置明显的增加了软件的使用难度。因此&#xff0c;研…

1076 Forwards on Weibo

1. 这题说的是&#xff0c;微博上人们之间有关注和被关注的关系&#xff0c;如果一个人发博&#xff0c;他的追随者就可能转发&#xff0c;追随者的追随者又可能转发&#xff0c;以此类推。现在给定一个人&#xff0c;求其微博可能被转发的人数&#xff0c;但是注意有一个关注链…

2014年个人工作总结

2014年的日常工作&#xff0c;从技术支持岗位调到市场.社区岗位上&#xff1a;日常技术处理工作变为博客、微信、微博、市场活动策划、发送奖品等。如果以此为界&#xff1a;即毕业10年内的主要是软件研发、团队管理、项目管理&#xff1b;第二个十年开始&#xff0c;有幸从事市…

DAL(数据库访问层)

using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Data;using System.Data.SqlClient;using System.Configuration; /// <summary>///DBHelper 的摘要说明/// </summary>public static class DBHelper{ public …

Navicat for Oracle

1、先解压Navicat for Oracle到任意目录 2、将instantclient-basic-nt-12.1.0.2.0解压到1中目录的instantclient_10_2文件夹下&#xff08;推荐&#xff0c;可随意&#xff09; 3、将instantclient-sqlplus-nt-12.1.0.2.0解压到instantclient_10_2文件夹中的 instantclient_12_…

1013 Battle Over Cities(图的DFS解法)

这题的背景是战争年代&#xff0c;假如城市1被占领&#xff0c;那么所有和城市1相关的公路都要被炸毁&#xff0c;但是这样一来&#xff0c;2和3就不连通了&#xff0c;所以需要补修一条23之间的公路。但是换做城市2或3被占领&#xff0c;1和另一座城市是联通的&#xff0c;并不…

你必须了解的微服务架构设计的10个要点!

近来&#xff0c;几乎人人都在谈论微服务。微服务之所以火热也是因为相对之前的应用开发方式有很多优点&#xff0c;如更灵活、更能适应现在需求快速变更的大环境等。本文将介绍微服务架构设计中的一些要点。 微服务架构设计时有哪些要点呢&#xff1f;先看下图是 Spring Cloud…

企业信息化中常见决策点应对

我和一位朋友在聊天的时候&#xff0c;谈起在甲方的做信息化&#xff0c;和在乙方做信息化的不同点在于&#xff0c;在甲方做信息化&#xff0c;需要搞定为什么要上一个项目。而乙方参与进来的时候&#xff0c;项目其实已经启动了。 是的&#xff0c;作为甲方的我们&#xff0c…

WebView调试

https://developer.chrome.com/devtools/docs/remote-debugging 转载于:https://www.cnblogs.com/daishuguang/p/4194882.html

1013 Battle Over Cities(并查集解法)

关于背景的介绍见1013 Battle Over Cities(图的DFS解法) DFS就是不算特定结点后数连通子图的总数&#xff0c;再减一。我想着那么并查集就是数不算特定节点后&#xff0c;集合元素(根)的个数。但是我弄错了一件事&#xff0c;我是边输入&#xff0c;边合并&#xff0c;然后对于…

FastDFS为什么要结合Nginx?

为什么选择Nginx Nginx 是一个很牛的高性能Web和反向代理服务器, 它具有有很多非常优越的特性: 在高连接并发的情况下&#xff0c;Nginx是Apache服务器不错的替代品: Nginx在美国是做虚拟主机生意的老板们经常选择的软件平台之一. 能够支持高达 50,000 个并发连接数的响应, 感谢…

STL容器[34]

SERVER以读打开FIFO&#xff1b;CLIENT以写打开FIFO&#xff1b;SERVER关闭FIFO&#xff1b;CLIENT向当前FIFO写数据&#xff0c;此时CLIENT获得一个SIGPIPE信号。如果忽略该信号&#xff0c;那么write将返回-1&#xff0c;ERRNO为EPIPE向一个写打开&#xff0c;当对端已经关闭…

企业可视化报表工具选型经验分享

选型背景 我们是一家面向金融行业的系统集成商&#xff0c;每年要做十几个项目&#xff08;看得出来我们并不大/笑哭&#xff09;&#xff0c;项目分大小、做事分先后&#xff0c;可不管怎样都绕不开数据&#xff0c;数据处理经常占项目的大头&#xff0c;所以经常会选择一些市…

1003 Emergency(Dijkstra,Bellman-Ford,SPFA三种解法)

目录 1. Dijkstra解法 2. Bellman-Ford解法 3. SPFA解法 4. Dijkstra解法AC代码 5. Bellman-Ford解法AC代码 6. SPFA解法AC代码 1. Dijkstra解法 这题不仅涉及到基础的解法&#xff0c;还涉及到第二标准(累计军队数量)&#xff0c;以及还要记录最短路径条数。这些都是在…