- 说说你对koa中洋葱模型的理解?
J轩
前端
什么是koa?Koa是一个精简的node框架,被认为是第二代Node框架,其最大的特点就是独特的中间件流程控制,是一个典型的洋葱模型,它的核心工作包括下面两个方面:1.将node原生的req和res封装成为一个context对象。2.基于async/await的中间件洋葱模型机制。Koa1和Koa2在源码上的区别有何不同?Koa1是使用generator、yield的模式。Koa2使用的是asyn
- Koa2——洋葱模型,简单实现
三千数优一
javascript1024程序员节
classapp{middleware=[];//装载中间件use(middleware){this.middleware.push(middleware);}compose(callback){//把要被触发的上一层洋葱壳作为下一层洋葱壳的next入参传入。//reducer的返回值,也就是下一层的next为()=>fn(next)。constreducer=(next,fn)=>()=>fn(
- koa2 洋葱模型
gaearon
koa2jsnodejsnode.jskoa2
示意图koa2是基于async和await实现的,使用next进行流程控制。这样就可以使用awaitnext()进行一种特殊的执行顺序,等下一个路由执行完毕之后,再执行当前路由,通常称为“洋葱模型”。何谓“洋葱模型”就像那首歌一样,“一层一层剥开我的心”,koa2中的“洋葱模型”也是这样,匹配到的路由,可以一层一层进去,进入最内层之后,再一层一层出来。例如这个demo:api.get("/",as
- Koa2 的洋葱模型是什么?它是如何实现的?
极客李华
Koakoa
Koa2的洋葱模型是什么?它是如何实现的?Koa2的洋葱模型是一种中间件执行流程的设计模式,它允许开发者在请求的处理过程中,按照特定的顺序依次执行一系列中间件函数。洋葱模型的实现基于Koa2框架的特性和原理。下面我将通过一个具体的案例来解释洋葱模型的概念和实现。假设我们有一个简单的Koa2应用,用于处理用户的HTTP请求。首先,我们需要创建一个Koa应用实例:constKoa=require('k
- koa学习
coder_vito
vue
为了弥补httpServer的不足,koa对其进行了一层封装,使之api更加的人性化。比如http中的res.end()api响应给客户端,因为是数据流,所以用end来结束好像也很合理,但是总觉得挺奇怪的,koa里则直接是res.body={},这样子的api就更加的人性化了。特点·koa2完全使⽤用Promise并配合async来实现异步·轻量量,⽆无捆绑·中间件架构·优雅的API设计·增强的错
- Koa框架入门
卷小白
npm前端node.js
Koa是一个基于Node.js的轻量级Web应用框架,它提供了一组简洁而强大的工具,帮助开发者构建高效、可扩展的Web应用程序。1.安装Koa要使用Koa框架,首先需要在项目中安装Koa的依赖。可以使用npm或者yarn来进行安装。在命令行中执行以下命令npminstallkoa或者yarnaddkoa2.创建Koa应用在项目的根目录下,创建一个新的JavaScript文件(例如app.js),并
- Mysql+Nodejs+Koa2+Vue+Quasar零起点教程5:安装vue+quasar
工程师54
一、安装vue全局安装vue脚手架:npminstall-gvue-cli二、安装quasar全局安装quasar脚手架:npminstall-g@quasar/cli三、创建项目(前端)在d:\eddysproject目录下执行:quasarcreatefront执行项目创建后显示内容比较多,上面是前面部分,下图是后面部分:创建项目框架后,package.json中涉及到的软件包都已经同步自动下
- Vue2+Echarts+koa2+websocket电商平台数据可视化实时检测系统后端项目搭建(二)
三月的一天
前端工程化echartswebsocket前端node.jskoa
1.KOA2——基于Node.js平台的Web服务器框架由Express原班人马打造ExpressKoa,Koa2都是Web服务器的框架,他们之间的差别和关系可以通过下面这个表格表示出框架名作用异步处理Expressweb框架回调函数Koaweb框架Generator+yieldKoa2web框架async/await环境依赖Nodev7.6.0及以上由于Koa2它是支持async和await,所
- Vue2+Echarts+koa2+websocket电商平台数据可视化实时检测系统(一)
三月的一天
echarts前端javascript
项目最终的效果如图所示,最终效果涉及到6个图表,5种图表类型,它们分别是折线图,柱状图,地图,散点图,饼图.。每个图表的数据都是从后端推送到前端来的,不过在项目的初期,我们会先使用ajax由前端主动获取数据,后续会使用WebSocket进行改造。整个项目的架构是基于Vue的,所以我们需要创建Vue项目,然后在Vue项目中开发各个图表组件。1.前端项目的准备1.1.vue-c1i脚手架创建项目1.1
- 前端小白快速撸懂 mysql + koa2
三猪技术团队
前端开发工程师为什么要学习node?实际开发中会用到吗?答案是肯定的。Node.js是前端工程师必学的,如果你想在软件开发这行走的更远的话。node.js并不难学,反而收益会很大。此篇文章针对与有node.js基础的项目的创建1.全局安装koa-generator快速生成器npminstallkoa-generator-g类似于express项目的快速生成器,有一个基本的模板进行使用k1.jpg安
- koa2 vue antd upload上传跨域问题
gzjiert
前端vue.jsjavascript前端
在使用antd的a-upload使用同现跨域在vue…config.js已配proxy代理且koa后台已配置跨域另起一个web服务不用a-upload上传没有出现跨域在koa中已设置了koa2-cors的跨域配置app.use(cors({//任何地址都可以访问origin:"*",maxAge:5,//指定本次预检请求的有效期,单位为秒。credentials:true,//是否允许发送Cook
- Vue+Koa2+mongodb 搭建项目
小明真的要加油
node.jsvuemongodbvuemongodbnode.js
文章目录前言一、项目用到的一些关键依赖二、后端框架的基础搭建1.安装koa-generator2.使用koa-generator生成koa项目3.启动项目三、前端框架的基本搭建1.安装vue-cli2.创建vue项目3.启动项目四、后端实现基础的登录注册1.基础登录(1).连接数据库(2)编写业务代码实现登录(3)声明路由(4)在postman工具中实验即可(5)其他比如注册方法等等流程类似,这里
- Vue+Koa项目完整上线流程中遇到的问题
Leo_DLi
前端javascriptKoa2
程序员有时候“提笔忘字”,以下是此次过程中遇到的问题流水账,按顺序记录的,不再细分什么前端后端了.有些问题可能过于简单,勿喷!1,Koa的get,post请求怎么获取参数get类请求:直接使用ctx.query来获取前端传递来的参数post类请求:需要使用到koa-bodyparser中间件,然后通过ctx.request.body来获取前端传递的参数koa-bodyparser在使用koa2指令
- Koa项目搭建----从零搭建Koa项目
Leo_DLi
Nodenode.jsKoaKoa2
最近发现使用Koa创建项目的博客比较多,但是不够细致,为方便自己和他人,遂整理本博客。本博客会介绍以下内容:1,安装Koa脚手架,即koa-generator2,创建Koa1+项目3,创建Koa2+项目4,坑5,项目运行建议阅读完博客之后再下手操作!!!一,安装Koa脚手架----koa-generator终端执行以下指令:npminstall-gkoa-generator二,创建Koa1+项目终
- Vue 3 + Koa2 + MySQL 开发和上线部署个人网站
Leo_DLi
Web前端VueNodemysql前端Koa2Vue
Vue3+Koa2+MySQL开发和上线部署个人网站记录个人的一个操作步骤,顺序不分先后,嫌啰嗦请出门右转!环境说明:服务器:阿里云轻量应用服务器服务器系统:CentOS8.2本地环境:macOS12.7.2Node:20.10.0MySQL:8.0.26Vue:3.3.11Koa:2.7.0pm2:5.3.1Nginx:1.14.1一,环境配置除Nginx外,服务器环境和本地环境都是上述配置,N
- vue3 + element-plus + koa2 实现图片上传至七牛云
0kime
前端vue.jsjavascriptelementuinode.js
koa2后端代码准备工作:安装koa-multerkoa-qiniukoa-uuid命令:npmikoa-multerkoa-qiniukoa-uuid-S1、新建utils文件夹新建QiniuConfig.js文件存放七牛云配置信息letQINIU={};QINIU.accessKey='xxx';//七牛的accessKeyQINIU.secretKey='xxx';//七牛的secretKe
- Vue3+Koa2实现图片上传(不再畏惧)
勇宝趣学前端
Vue前端vue.jsjavascriptnode.js
大家好,我是勇宝,一个热爱前端的小学生,年关将至,提前祝大家新年快乐。今天呢,我们就来好好的啃一啃图片上传,从一个前端开发者的角度来探讨一下图片上传前后端到底都做了哪些事情。文章目录一、技术摘要二、图片上传流程概述1.前端2.后端三、项目搭建前端1.初始化Vue后端(koa2)1.全局安装脚手架2.初始化项目3.运行四、开始撸代码1.编写html骨架2.定义回显元素3.编写选择按钮逻辑4.回显选择
- express/koa2中使用http-proxy-middleware代理转发后端接口解决跨域问题
竹子js
express
由于后端接口没有设置允许跨域,故前端需要自己解决,如果前端项目是node起的服务,可以使用express/koa2框架,配合http-proxy-middleware中间件转发后端接口express中:1.先安装依赖npmihttp-proxy-middleware-D2.设置代理,可配置多条varapp=express();//设置反向代理解决跨域,类似nginx的反向代理,参考https://
- koa2 compose
wish_dd
functioncompose(middleware){//检查输入有效性确保输入为函数数组if(!Array.isArray(middleware))thrownewTypeError('Middlewarestackmustbeanarray!')for(constfnofmiddleware){if(typeoffn!=='function')thrownewTypeError('Middl
- Angular封装HttpClient文件下载
千寻物语
Angularangular.jsHttpClient文件下载
AngularHttpClient文件下载前言HttpRequest.tsdemo后端接口koa2示例功能优化实现下载进度监控前言使用Angular框架开发工作中,实现文件下载业务时,我们可以使用Angular自带的HttpClient。下面我们就封装一下HttpClient实现文件下载,当接口返回文件流正常下载,后端返回json错误信息时,前端可以获取到错误信息进行toast提示HttpRequ
- MySQL创建数据库连接池
林_深时见鹿
适用于Koa2和Express进行连接安装mysql驱动npminstallmysql--save创建mysql数据连接池,封装mysql请求constmysql=require('mysql');constpool=mysql.createPool({host:'127.0.0.1',user:'root',password:'root',database:'mydatabase'});letq
- node.js + koa2学习笔记
趁着年轻吃点苦
koa2javascriptnode.js
介绍Koa2koa2-创建项目//全局安装koa-generatornpminstallkoa-generator-g//利用koa-generator快速生成ejs模板的项目koa2koa-weibo-ekoa2-演示路由//实例化一个路由constrouter=require('koa-router')()//为这个路由添加前缀名router.prefix('/api/user')//处理ge
- Mysql+Nodejs+Koa2+Vue+Quasar零起点教程6:创建mysql数据库
工程师54
一、root登录d:\mysql\bin>mysql-uroot-p123二、创建数据库CREATEDATABASEIFNOTEXISTStest_db1;三、创建用户CREATEUSER'testuser1'@'localhost'IDENTIFIEDBY'123456';命令:CREATEUSER'username'@'host'IDENTIFIEDBY'password';说明:userna
- koa2实践项目-进阶
人穷脸丑小前端
路由koa-generator是把路由放到了app.js里面了,这里我单独提出来建立router.js,然后app.js引入。这是我的项目目录上面是我的项目目录,后面慢慢解释。routes和api两个文件夹,其实都算路由配置,只不过我把后端渲染的页面数据和提供的接口数据分开放了,routes里面路由是渲染ejs模板,api里面的提供前后端分离的接口。下面是router.js代码constRoute
- nodejs + nodemailer 实现发送邮件功能
0000000asdasd
qq邮箱的授权码的获取方式https://service.mail.qq.com/cgi-bin/help?subtype=1&id=28&no=1001256163邮箱的授权码的获取方式http://www.downxia.com/zixun/19894.html官方文档https://nodemailer.com/about/用的是nodejs+koa2//首先引入importNodemail
- Vue+Koa2 搭建前后端分离项目
Leo_DLi
VueNodeVueKoa2跨域
Vue+Koa2搭建前后端分离项目简单的一个Demo演示:Vue和Koa2在本地搭建前后端分离项目.重点:跨域当前环境:1,Vite搭建的Vue前端项目(也就是Vue3了).2,Koa2搭建的后端项目.前端项目在localhost:5173端口下运行,后端项目在localhost:3000端口下运行,因此,前端通过Ajax请求后端的接口就会存在跨域问题.本文的终点也在聊如何实现跨域.一,Vue前端
- 校园管理系统 总结
去年的牛肉
介绍school-manager校园管理后台服务实现了简单的校园管理业务。特点是环境基础良好,适合教学,和二次开发。学校增删盖查专业增删改查班级层删改查学生增删改查老师增删改查软件架构nodejs(koa2mongoose)element-uiadmin-element开发工具数据库:mongodbide(项目开发工具):webstorm安装教程一.后台服务代码地址school-manager-s
- 2018-06-28 koa2的入坑之路
十月鹰飞
首先吐槽下阿里云的轻云服务器。其次感慨下自己给自己挖的大坑。最后来看nodeJS的web开发。打算用koa2来开发公司的企业网站。
- KOA2 + MongoDB 和 MySQL混用的项目 nodejs restful API框架
狼丶宇先森
有时候因项目需要.在koa中需要使用多个数据库和多种数据库此以MongoDB和MySQL为例此项目中用到了2个MySQL和多个MongoDB,其中MongoDB的库名生成是由时间生成的如2018_11_09,这种采用动态库名链接的方式进行连接.github地址:https://github.com/langyuxiansheng/base-restfulapi-server可以与配套的管理后台一起
- koa2入门
大乔是个美少女
【链接】koa入门https://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000/001471087582981d6c0ea265bf241b59a04fa6f61d767f6000【链接】「新手向」koa2从起步到填坑http://www.jianshu.com/p/6b816c609669【
- springmvc 下 freemarker页面枚举的遍历输出
杨白白
enumfreemarker
spring mvc freemarker 中遍历枚举
1枚举类型有一个本地方法叫values(),这个方法可以直接返回枚举数组。所以可以利用这个遍历。
enum
public enum BooleanEnum {
TRUE(Boolean.TRUE, "是"), FALSE(Boolean.FALSE, "否");
- 实习简要总结
byalias
工作
来白虹不知不觉中已经一个多月了,因为项目还在需求分析及项目架构阶段,自己在这段
时间都是在学习相关技术知识,现在对这段时间的工作及学习情况做一个总结:
(1)工作技能方面
大体分为两个阶段,Java Web 基础阶段和Java EE阶段
1)Java Web阶段
在这个阶段,自己主要着重学习了 JSP, Servlet, JDBC, MySQL,这些知识的核心点都过
了一遍,也
- Quartz——DateIntervalTrigger触发器
eksliang
quartz
转载请出自出处:http://eksliang.iteye.com/blog/2208559 一.概述
simpleTrigger 内部实现机制是通过计算间隔时间来计算下次的执行时间,这就导致他有不适合调度的定时任务。例如我们想每天的 1:00AM 执行任务,如果使用 SimpleTrigger,间隔时间就是一天。注意这里就会有一个问题,即当有 misfired 的任务并且恢复执行时,该执行时间
- Unix快捷键
18289753290
unixUnix;快捷键;
复制,删除,粘贴:
dd:删除光标所在的行 &nbs
- 获取Android设备屏幕的相关参数
酷的飞上天空
android
包含屏幕的分辨率 以及 屏幕宽度的最大dp 高度最大dp
TextView text = (TextView)findViewById(R.id.text);
DisplayMetrics dm = new DisplayMetrics();
text.append("getResources().ge
- 要做物联网?先保护好你的数据
蓝儿唯美
数据
根据Beecham Research的说法,那些在行业中希望利用物联网的关键领域需要提供更好的安全性。
在Beecham的物联网安全威胁图谱上,展示了那些可能产生内外部攻击并且需要通过快速发展的物联网行业加以解决的关键领域。
Beecham Research的技术主管Jon Howes说:“之所以我们目前还没有看到与物联网相关的严重安全事件,是因为目前还没有在大型客户和企业应用中进行部署,也就
- Java取模(求余)运算
随便小屋
java
整数之间的取模求余运算很好求,但几乎没有遇到过对负数进行取模求余,直接看下面代码:
/**
*
* @author Logic
*
*/
public class Test {
public static void main(String[] args) {
// TODO A
- SQL注入介绍
aijuans
sql注入
二、SQL注入范例
这里我们根据用户登录页面
<form action="" > 用户名:<input type="text" name="username"><br/> 密 码:<input type="password" name="passwor
- 优雅代码风格
aoyouzi
代码
总结了几点关于优雅代码风格的描述:
代码简单:不隐藏设计者的意图,抽象干净利落,控制语句直截了当。
接口清晰:类型接口表现力直白,字面表达含义,API 相互呼应以增强可测试性。
依赖项少:依赖关系越少越好,依赖少证明内聚程度高,低耦合利于自动测试,便于重构。
没有重复:重复代码意味着某些概念或想法没有在代码中良好的体现,及时重构消除重复。
战术分层:代码分层清晰,隔离明确,
- 布尔数组
百合不是茶
java布尔数组
androi中提到了布尔数组;
布尔数组默认的是false, 并且只会打印false或者是true
布尔数组的例子; 根据字符数组创建布尔数组
char[] c = {'p','u','b','l','i','c'};
//根据字符数组的长度创建布尔数组的个数
boolean[] b = new bool
- web.xml之welcome-file-list、error-page
bijian1013
javaweb.xmlservleterror-page
welcome-file-list
1.定义:
<welcome-file-list>
<welcome-file>login.jsp</welcome>
</welcome-file-list>
2.作用:用来指定WEB应用首页名称。
error-page1.定义:
<error-page&g
- richfaces 4 fileUpload组件删除上传的文件
sunjing
clearRichfaces 4fileupload
页面代码
<h:form id="fileForm"> <rich:
- 技术文章备忘
bit1129
技术文章
Zookeeper
http://wenku.baidu.com/view/bab171ffaef8941ea76e05b8.html
http://wenku.baidu.com/link?url=8thAIwFTnPh2KL2b0p1V7XSgmF9ZEFgw4V_MkIpA9j8BX2rDQMPgK5l3wcs9oBTxeekOnm5P3BK8c6K2DWynq9nfUCkRlTt9uV
- org.hibernate.hql.ast.QuerySyntaxException: unexpected token: on near line 1解决方案
白糖_
Hibernate
文章摘自:http://blog.csdn.net/yangwawa19870921/article/details/7553181
在编写HQL时,可能会出现这种代码:
select a.name,b.age from TableA a left join TableB b on a.id=b.id
如果这是HQL,那么这段代码就是错误的,因为HQL不支持
- sqlserver按照字段内容进行排序
bozch
按照内容排序
在做项目的时候,遇到了这样的一个需求:
从数据库中取出的数据集,首先要将某个数据或者多个数据按照地段内容放到前面显示,例如:从学生表中取出姓李的放到数据集的前面;
select * fro
- 编程珠玑-第一章-位图排序
bylijinnan
java编程珠玑
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.Writer;
import java.util.Random;
public class BitMapSearch {
- Java关于==和equals
chenbowen00
java
关于==和equals概念其实很简单,一个是比较内存地址是否相同,一个比较的是值内容是否相同。虽然理解上不难,但是有时存在一些理解误区,如下情况:
1、
String a = "aaa";
a=="aaa";
==> true
2、
new String("aaa")==new String("aaa
- [IT与资本]软件行业需对外界投资热情保持警惕
comsci
it
我还是那个看法,软件行业需要增强内生动力,尽量依靠自有资金和营业收入来进行经营,避免在资本市场上经受各种不同类型的风险,为企业自主研发核心技术和产品提供稳定,温和的外部环境...
如果我们在自己尚未掌握核心技术之前,企图依靠上市来筹集资金,然后使劲往某个领域砸钱,然
- oracle 数据块结构
daizj
oracle块数据块块结构行目录
oracle 数据块是数据库存储的最小单位,一般为操作系统块的N倍。其结构为:
块头--〉空行--〉数据,其实际为纵行结构。
块的标准大小由初始化参数DB_BLOCK_SIZE指定。具有标准大小的块称为标准块(Standard Block)。块的大小和标准块的大小不同的块叫非标准块(Nonstandard Block)。同一数据库中,Oracle9i及以上版本支持同一数据库中同时使用标
- github上一些觉得对自己工作有用的项目收集
dengkane
github
github上一些觉得对自己工作有用的项目收集
技能类
markdown语法中文说明
回到顶部
全文检索
elasticsearch
bigdesk elasticsearch管理插件
回到顶部
nosql
mapdb 支持亿级别map, list, 支持事务. 可考虑做为缓存使用
C
- 初二上学期难记单词二
dcj3sjt126com
englishword
dangerous 危险的
panda 熊猫
lion 狮子
elephant 象
monkey 猴子
tiger 老虎
deer 鹿
snake 蛇
rabbit 兔子
duck 鸭
horse 马
forest 森林
fall 跌倒;落下
climb 爬;攀登
finish 完成;结束
cinema 电影院;电影
seafood 海鲜;海产食品
bank 银行
- 8、mysql外键(FOREIGN KEY)的简单使用
dcj3sjt126com
mysql
一、基本概念
1、MySQL中“键”和“索引”的定义相同,所以外键和主键一样也是索引的一种。不同的是MySQL会自动为所有表的主键进行索引,但是外键字段必须由用户进行明确的索引。用于外键关系的字段必须在所有的参照表中进行明确地索引,InnoDB不能自动地创建索引。
2、外键可以是一对一的,一个表的记录只能与另一个表的一条记录连接,或者是一对多的,一个表的记录与另一个表的多条记录连接。
3、如
- java循环标签 Foreach
shuizhaosi888
标签java循环foreach
1. 简单的for循环
public static void main(String[] args) {
for (int i = 1, y = i + 10; i < 5 && y < 12; i++, y = i * 2) {
System.err.println("i=" + i + " y="
- Spring Security(05)——异常信息本地化
234390216
exceptionSpring Security异常信息本地化
异常信息本地化
Spring Security支持将展现给终端用户看的异常信息本地化,这些信息包括认证失败、访问被拒绝等。而对于展现给开发者看的异常信息和日志信息(如配置错误)则是不能够进行本地化的,它们是以英文硬编码在Spring Security的代码中的。在Spring-Security-core-x
- DUBBO架构服务端告警Failed to send message Response
javamingtingzhao
架构DUBBO
废话不多说,警告日志如下,不知道有哪位遇到过,此异常在服务端抛出(服务器启动第一次运行会有这个警告),后续运行没问题,找了好久真心不知道哪里错了。
WARN 2015-07-18 22:31:15,272 com.alibaba.dubbo.remoting.transport.dispatcher.ChannelEventRunnable.run(84)
- JS中Date对象中几个用法
leeqq
JavaScriptDate最后一天
近来工作中遇到这样的两个需求
1. 给个Date对象,找出该时间所在月的第一天和最后一天
2. 给个Date对象,找出该时间所在周的第一天和最后一天
需求1中的找月第一天很简单,我记得api中有setDate方法可以使用
使用setDate方法前,先看看getDate
var date = new Date();
console.log(date);
// Sat J
- MFC中使用ado技术操作数据库
你不认识的休道人
sqlmfc
1.在stdafx.h中导入ado动态链接库
#import"C:\Program Files\Common Files\System\ado\msado15.dll" no_namespace rename("EOF","end")2.在CTestApp文件的InitInstance()函数中domodal之前写::CoIniti
- Android Studio加速
rensanning
android studio
Android Studio慢、吃内存!启动时后会立即通过Gradle来sync & build工程。
(1)设置Android Studio
a) 禁用插件
File -> Settings... Plugins 去掉一些没有用的插件。
比如:Git Integration、GitHub、Google Cloud Testing、Google Cloud
- 各数据库的批量Update操作
tomcat_oracle
javaoraclesqlmysqlsqlite
MyBatis的update元素的用法与insert元素基本相同,因此本篇不打算重复了。本篇仅记录批量update操作的
sql语句,懂得SQL语句,那么MyBatis部分的操作就简单了。 注意:下列批量更新语句都是作为一个事务整体执行,要不全部成功,要不全部回滚。
MSSQL的SQL语句
WITH R AS(
SELECT 'John' as name, 18 as
- html禁止清除input文本输入缓存
xp9802
input
多数浏览器默认会缓存input的值,只有使用ctl+F5强制刷新的才可以清除缓存记录。如果不想让浏览器缓存input的值,有2种方法:
方法一: 在不想使用缓存的input中添加 autocomplete="off"; eg: <input type="text" autocomplete="off" name