首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在input中回车后页面提交导致出现HTTP 错误 405.0 - Method Not Allowed

前些时间在做一个搜索功能时发现一个比较有意思的现象,场景是这样的:在一个模态窗口中是一个订单列表,页面的顶部有若干个状态筛选框和一个搜索关键字输入框,当焦点在关键字输入框时按回车,本来是对input的keyup...事件做了监听,当发现是按了回车键时便自动提交搜索请求的,但输入关键字后按回车时页面竟然跳转了,并且出现“HTTP 错误 405.0 - Method Not Allowed无法显示您正在查找的页面,因为使用了无效方法...(HTTP 谓词)”的错误,非常纳闷。...按照错误信息及现象(页面跳转了)来看,应该是因为触发了页面提交了,但事实上,当在keyup事件里面alert时,根本还没有执行到keyup事件里面去就已经跳转了。...自动提交的动作本身浏览器在默认事件中绑定的,按键盘的操作就是keyup和keydown,我原本的按键监听是在keyup事件里写的,所以把keydown事件重写,然后终止默认事件执行就OK了。

1.9K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Angular 从入坑到挖坑 - HTTP 请求概览

    一、Overview angular 入坑记录的笔记第四篇,介绍在 angular 中如何通过 HttpClient 类发起 http 请求,从而完成与后端的数据交互。...4.2.1、获取错误信息 在涉及到前后端交互的过程中,不可避免会出现各种状况,在出现错误时,可以在 subscribe 方法中,添加第二个回调方法来获取错误信息 getQuotes() { this.services.getAntiMotivationalQuotes...在处理错误信息的回调方法中,方法返回了一个 HttpErrorResponse 对象来描述错误信息 因为这里的错误更多是服务在与后端进行通信产生的错误,因此对于错误信息的捕获和处理更应该放到服务中进行,...而在组件处仅显示错误提示 在服务中定义一个错误处理器,用来处理与后端请求中发生的错误 import { Injectable } from '@angular/core'; import { Observable...4.2.2、请求重试 某些情况下存在因为特殊原因导致短时间的请求失败,这时可以在 pipe 管道中,当请求失败后,使用 retry 方法进行多次的请求重试,在进行了多次重试后还是无法进行数据通信后,则进行错误捕获

    5.3K10

    2018年前端面试总结

    中SVG的溢出、许多出现在各浏览器和操作系统中的与表单相关的bug。...5开头(服务器错误)这些状态代码表示服务器在尝试处理请求时发生内部错误。 这些错误可能是服务器本身的错误,而不是请求出错。 500 (服务器内部错误) 服务器遇到错误,无法完成请求。...7.常见的HTML状态码及其的含义 1XX:信息状态码 100 Continue 继续,一般在发送post请求时,已发送了http header之后服务端将返回此信息,表示确认,之后发送具体参数信息...5XX: 服务器错误 500 Internal Server Error 最常见的服务器端错误。 503 Service Unavailable 服务器端暂时无法处理请求(可能是过载或维护)。...框架比较臃肿,每次用啥功能要引入一大堆东西 Angular错误提示不够清晰明显,对于初级开发者,很难看懂Angular的错误提示。

    72920

    hash和history路由模式

    其实就是说,我们点击页面上的一些东西,并没有真正的发送请求进行页面跳转,而是在组件之间切换而已,仅仅刷新局部资源。.../login 关键在这里,当我们在 http://‍website.com/login 页执行刷新操作,会向真正的服务器发送请求资源,nginx location 是没有相关配置的,所以就会出现 404......只有 http://website.com 会被包含在请求中 ,因此对于服务端来说,即使没有配置location,也不会返回404错误 简单来说: 前端打包后的 dist 包中,只有 index.html...hash 模式:只将 hash 前面的部分当作地址 history 模式:会将地址栏中的地址全部看作请求地址 hash模式的优缺 兼容低版本浏览器,Angular1.x和Vue默认使用的就是hash路由...只有#符号之前的内容才会包含在请求中被发送到后端,也就是说就算后端没有对路由全覆盖,但是不会返回404错误 hash值的改变,都会在浏览器的访问历史中增加一个记录,所以可以通过浏览器的回退、前进按钮控制

    22410

    Angular 项目实现权限控制

    上一篇文章我们讲到了 Angular 组件通信。本文我们讲讲,在项目开发中,你是否会遇到这样的需求: 请根据用户登陆,限制其访问的内容。 So,这就是要进行权限控制。...返回的数据格式需要我们按照自己在 app-routing.module.ts 中编写好的路由路径对应。...path: 'department', // 部门列表 component: DepartmentComponent } ] }, // ... ] 在页面中...url 字段 - 菜单的路由,对应 app-routing.module.ts 中的完整的 path icon 字段 - 标题前的小图标,二级标题没有 is_open 字段 - 菜单是否展开的标识 此时...小到控制用户的一个按钮的展示等,但是本质来说,都是对后端接口请求的限制。比如,你请求一个列表,但是你没有权限,那么你就请求不了,报 401 的错误。

    81520

    Python pandas获取网页中的表数据(网页抓取)

    当我们访问一个网站时,发生的事情如下: 1.在浏览器的地址栏中输入地址(URL),浏览器向目标网站的服务器发送请求。 2.服务器接收请求并发回组成网页的HTML代码。...Web抓取基本上意味着,我们可以使用Python向网站服务器发送请求,接收HTML代码,然后提取所需的数据,而不是使用浏览器。...例如,以下HTML代码是网页的标题,将鼠标悬停在网页中该选项卡上,将在浏览器上看到相同的标题。...简要说明如下: …绘制表格 …在表中绘制一行 …表示表格标题 …表示表格数据 ...fr=aladdin 图1(如果出现错误,根据错误提示处理。我的计算机上是没有安装lxml,安装后正常) 上面的df实际上是一个列表,这很有趣……列表中似乎有3个项目。

    8.1K30

    AngularJS 与 server 通信

    一、搭建AngularJS 框架 详细过程请参考官网教程:https://angular.io/guide/quickstart image.png 在上面的截图中出现了两个错误提示: 1. ng...第二个错误是因为我启动了其他angular项目,导致端口被占用,关掉其他项目就释放了4200端口,当然也可以在程序中修改端口号 image.png 启动成功以后,浏览器会弹出相应的欢迎页面 image.png...在src-->app-->app.component.ts 文件中配置HTTP请求 import {Component, OnInit} from '@angular/core'; import {Http...在app.moudule.ts中引入HTTP模块 import { BrowserModule } from '@angular/platform-browser'; import { NgModule... ng serve --proxy-config proxy.conf.json 所有以de开头的URL请求都会发送到target image.png 5.启动server端的服务 image.png

    63520

    (翻译)开始使用ABP.CORE模板 (ASP.NET Core with Angular)

    如果在运行过程中出现什么问题,请尝试关闭你的vs然后重新打开。往往在第一次还原包的时候容易失败。...就翻译到这里把,因为npm编译出现错误,一时半会也解决不了。 ?...如上所示我们发送用户名和密码的值,结果返回JSON数据包含令牌和过期时间(默认是24小时,可以配置)。我们可以保存它并用于下一个请求。...我们只需要向http://localhost:21021/api/services/app/user/getAll 发送一个get请求,包含Content-Type="application/json"...这个应用程序从主机的appsettings.json文件中获取连接字符串。开始它和Web.Host中的appsettings.json文件一样。确保在配置文件中的连接字符串是要数据库。

    2.9K20

    前端开发:vue路由之前端路由的原理

    两种实现方式 1、hash模式 这里的hash是指url尾巴后的#号及后面的字符。这里的#和css里的#是一个意思。hash也称作锚点,本身是用来做页面定位的,她可以使对应id的元素显示在可是区域内。...由于hash值变化不会导致浏览器向服务器发出请求,而且hash改变会触发hashchange事件,浏览器的进后退也能对其进行控制,所以人们在 html5 的 history 出现前,基本都是使用 hash...通过这两个方法可以改变url且不向服务器发送请求。同时不会像hash有一个#,更加的美观。...里获取 // title:标题,基本没用,一般传 null // url:设定新的历史记录的 url。...其次,hash 的传参是基于 url 的,如果要传递复杂的数据,会有体积的限制,而 history 模式不仅可以在url里放参数,还可以将数据存放在一个特定的对象中。

    99351

    构建具有用户身份认证的 Ionic 应用

    你可以使用 Chrome 的设备模式查看应用程序在 iPhone 6 中的效果。 ? 使用 Ionic serve 命令的特点是它会在浏览器中显示编译错误,而不是(有时会隐藏)在开发控制台。...出现这个错误是因为 OAuthService 需要依赖 Angular 的 Http 模块,但是还没有将该模块导入到项目中。...它们用于访问被保护的资源,通常是在发送请求时将它们添加到 Authentication 请求头中。...比如, 在 在 Angular PWA 中添加身份认证中,有一个 BeerService ,它用于在发送 API 请求时携带 access token 。...如果打开 Network 标签,你会看到只发送了一条请求 (to /authn),它和在浏览器中发送的两条请求 (to /authn and /authorize) 有所不同。 ?

    23.3K50

    构建具有用户身份认证的 Ionic 应用

    你可以使用 Chrome 的设备模式查看应用程序在 iPhone 6 中的效果。 ? 使用 Ionic serve 命令的特点是它会在浏览器中显示编译错误,而不是(有时会隐藏)在开发控制台。...出现这个错误是因为 OAuthService 需要依赖 Angular 的 Http 模块,但是还没有将该模块导入到项目中。...它们用于访问被保护的资源,通常是在发送请求时将它们添加到 Authentication 请求头中。...比如, 在 在 Angular PWA 中添加身份认证中,有一个 BeerService ,它用于在发送 API 请求时携带 access token 。...如果打开 Network 标签,你会看到只发送了一条请求 (to /authn),它和在浏览器中发送的两条请求 (to /authn and /authorize) 有所不同。 ?

    23.8K00

    深究AngularJS(3)——$res

    对于设置的没有出现在url模板(第一个参数)中的参数,将会以search query的方式添加,例如: 如果url模板为/codingcool/:author,paramDefaults为{author...,数据从服务器端取回后,被封装到一个$resource服务的一个对象实例中,这个对象可以被save,remove,delete方法直接操作,这种封装并提供简单的CRUD操作的方式,使得开发者可以感受到被尊重啊...User.get({id:'123'}, successFn, errorFn); 该方法向url发送一个get请求,并期望一个json类型的响应。...这里会向/api/users/123发送一个请求,successFn处理请求成功响应,errorFn处理错误。...save(params, payload, successFn, errorFn); save方法会发起一个post请求,params参数用来填充url中变量,对象payload会作为请求体进行发送

    1.1K10

    AngularDart4.0 英雄之旅-教程-08HTTP 顶

    错误处理 在getHeroes()的结尾处,您可以捕获服务器故障并将其传递给错误处理程序。 } catch (e) { throw _handleError(e); } 这是关键的一步。...; 在现实生活中,你会处理代码中的错误。...更新英雄的细节 尝试在英雄详情视图中编辑英雄的名字。 当你输入时,英雄的名字在视图标题中被更新。 但是,如果您单击后退按钮,更改将丢失。 更新之前没有丢失。 什么改变了?...当用户在搜索框中输入一个名字时,你会对这个名字过滤的英雄进行重复的HTTP请求。 首先创建HeroSearchService,将搜索查询发送到服务器的Web API。...你永远不会比300ms更频繁地发出请求。 distinct()确保仅当过滤器文本发生更改时才发送请求。

    11K30

    【Hybrid开发高级系列】AngularJS(二)——常用$服务

    $apply()方法可以在angular框架之外执行angular JS的表达式,例如:DOM事件、setTimeout、XHR或其他第三方的库。..., PUT     url: 字符串,请求的目标     params: 字符串或者对象,会被转换成为查询字符串追加的url后面     data: 在发送post请求时使用,作为消息体发送到服务器     ...拦截器允许你: 通过实现 request 方法拦截请求:         该方法会在 http 发送请求道后台之前执行,因此你可以修改配置或做其他的操作。...通过实现 requestError 方法拦截请求异常:         有时候一个请求发送失败或者被拦截器拒绝了。请求异常拦截器会俘获那些被上一个请求拦截器中断的请求。...replace( ):如果被调用,就会用改变后的URL直接替换浏览器中的历史记录,而不是在历史记录中新建一条信息,这样可以阻止『后退』。

    45440

    Ng-Matero:基于 Angular Material 搭建的中后台管理框架

    经过一个多月的设计与思考,我开发了这款基于 Angular Material 的中后台管理框架,初期架构设计已经完成,在接下来的版本中会提供 schematics 支持及 vscode snippet... 配置布局 通过在 settings 服务中传入配置对象可以配置页面的布局,比如 // 配置选项接口 export interface Defaults { showHeader...: ChildrenItem[]; } 菜单服务会注入到根组件,通过 getAll() 可以获取到全部菜单,同样是在初始化数据后通过 set() 方法设置好菜单。...,文本色则是 .text-red-500,与之对应的对比色可以是 .text-light,.text-dark 页面标题 框架默认提供了 page-header 和 breadcrumb 两个通用组件,...同样支持颜色系统,可以直接添加颜色类来改变页面标题部分的颜色,如下: 500"> 辅助类 Helper 编写延续了

    3K20

    Angular系列教程-第六节

    1.第三方类库使用 2.rxjs库使用 网络请求HttpClient 3.编译发布 ng build –base-href /angular/my-test-app/ –prod 4.使用bootstrap...bootcss.com/css/#responsive-utilities 5.管道 date json lowercase 转小写 uppercase 转大写 titlecase 把文本转换成标题形式...7.安全 XSS攻击 跨站脚本(XSS)允许攻击者将恶意代码注入到页面中。这些代码可以偷取用户数据 (特别是它们的登录数据),还可以冒充用户执行操作。...它是 Web 上最常见的攻击方式之一 XSRF 在跨站请求伪造(XSRF 或 CSFR)中,攻击者欺骗用户,让他们访问一个假冒页面(例如 evil.com), 该页面带有恶意代码,秘密的向你的应用程序服务器发送恶意请求...8.i18n国际化 日期、数字、百分比以及货币等 9.API手册使用 https://angular.cn/api https://angular.io/api

    64520
    领券