很多朋友对于vue获取服务器时间和vue前端抓包抓不上json不太懂,今天就由小编来为大家分享,希望可以帮助到大家,下面一起来看看吧!
一、在nginx+vue.js中如何实现前后端分离
这篇文章主要介绍了nginx+vue.js实现前后端分离的示例代码,现在分享给大家,也给大家做个参考。
1.nginx是一个高*能的HTTP和反向代理服务器,常用于分布式服务器管理.
它常用于做负载均衡(通过调用多台服务器达到此目的)
静态资源输出更快,可以对资源实现gzip压缩后输出(这也是本文为什么用它做静态资源访问的一个重要原因)
适合解决跨域问题和反向代理(因为谁也不想看到在本域名下看到访问其他域名的情况发生,跨域可导致csrf攻击,这是本文用它的第二个原因)
占用内存少,秒启,能快速切换结点,防止宕机
2.es6是ECMAScript的第六个版本,如果想要学好vue.js等js框架,这是必须要学会的一门语言,推荐学习如下:
3.vue.js是一款前端模板渲染引擎,类似于后端的jsp,beetl等模板引擎.当然结合node环境也可作为后端渲染用.(官网已支持)
说了上述几点,让我们来回答几个为什么?
1.实现前后端分离的好处是什么?主要应用场景在哪?
2.为什么有了后端模板引擎,为什么还要用前端的模板引擎?他们的优势和劣势?
3.实现前后端分离需要怎么改?
长长的分割线思考后???????????
1.首先是发展的眼光看问题,以前的项目大多呈现的是PC端项目,且场景简单,固定.请求大多是有状态的.而现在我们常常是移动端项目较多,同一款大多是原生和内嵌页面相结合的方式.并且现在的项目场景更多元化,这导致一个功能模块很可能是好几个项目的请求共同作用的结果.
2.如果还按照以前的做法,第一个问题是我只能用jsonp去解决调多个跨域请求的问题,实现起来代码太过冗余。对于同一功能,很有可能端和PC端就有两套不同的写法。并且带宽是个很贵的东西,客户端总是去服务器端一起静态资源的请求,会导致速度慢。动静分离可以实现静态资源和动态资源分开获取,并且服务器也能动静分离,有效解决带宽问题。
3.后端开发人员对于css,js的掌握可能不如前端熟练,比如利用jsp填充数据时,往往需要后端开发人员去调样式和写js,这样会造成开发效率低下。
4.采用前端模板渲染可以释放服务器端的一部分压力,并且前端模板引擎支持的功能比后端丰富.比如用vue可以自定义组件,校验方式,深入式渐变等,这比后端模板引擎功能要更加丰富.
4.我们的解决方案如下
1.传统的交互方式:
客户端发起请求,服务器端响应,经过一系列操作生成动态数据,将动态数据交由后端模板引擎,经过渲染后,传递给前端.
2.改良的交互方式
客户端发起请求,nginx拦截,若是静态资源,则交由文件服务器压缩后发送至前端.若是动态资源请求,则经过动态资源服务器生成动态数据,以json格式返回至前端,交由vue.js渲染处理后进行展示.
5.vue.js 2.x版的重点功能讲解
1.怎样和html结构进行绑定,怎样和样式进行动态绑定,常用的监听事件有哪些
1.基本的渲染
//html结构
<p id="">
{{ message}}
</p>
//js模块
var = new Vue({
//会检索绑定的id如果是class则是.class即可绑定
el:'#',
data:{
message:'Hello Vue!'
}
})2.class与style绑定
<p class="static"
v-bind:class="{ active: isActive,'text-danger': hasError}">
</p>
data:{
isActive: true,
hasError: false
}
渲染结果为:<p class="static active"></p>3.常用的绑定事件
//输出html
<p v-html="rawHtml"></p>
//绑定id或class
<p v-bind:id="dynamicId"></p>
//绑定herf
<a v-bind:href="url" rel="external nofollow"></a>
//绑定onclick
<a v-on:click="doSomething"></a>2.和服务器怎样进行通讯
在这里推荐大家使用axios进行和服务端的请求,然后将请求后的数据交由vue.js处理.
关于axios的使用例子
3.常见的流程控制语句数据校验自定义指令
//if语句
<h1 v-if="ok">Yes</h1>
//for循环语句
<ul id="example-1">
<li v-for="item in items">
{{ item.message}}
</li>
</ul>数据校验及其表单控件绑定()
以下四点参考官网api,不再做介绍了
4.深入响应式怎样实现(在第一次页面初始化填值后,如果发生改变要修改怎么做)?
5.自定义组件应用及其使用Render创建Html结构
6.路由的使用
7.常见的修饰符
6.实战举例
1.nginx配置静态资源
server{
listen 0;
server_name
charset utf-8;
index/static/index.html;//配置首页
//这边可使用正则表达式,拦截动态数据的请求,从而解决跨域问题
location=/sellingJson.html{
proxy_pass ;
}
#配置Nginx动静分离,定义的静态页面从static读取。
location~.*\.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$
{
root/static/;
#expires定义用户浏览器缓存的时间为7天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力
expires 7d;
}
}2.后端请求返回json数据(以j*a为例)
@RequestMing("/vueHelpSellingcar.html")
public void vueHelpSellingcar(HttpServletRequest request,HttpServletResponse response){
//若干操作后,返回json数据
JSONObject resultJson= new JSONObject();
resultJson.put("carbrandList", carbrandList);
resultJson.put("provinceList", provinceList);
//进行序列化,返回值前端
try{
byte[] json=resultJson.toString().getBytes("utf-8");
response.setHeader("Content-type","text/html;charset=UTF-8");
response.getOutputStream().write(json);
} catch(Exception e){
e.printStackTrace();
}
}3.前端调用vue示例
//html模块
<p v-if="carbrandList.length" class="char_contain">
<p v-for="brand in carbrandList" id="{{brand.brand_id}}">{{brand.brand_name}}</p>
</p>
//js模块页面加载后,自动去获取动态资源
let v={};
$(function(){
axios.get(';)
.then(function(data){
//定义一个vue对象,方便模板渲染
v=Object.assign(v, new Vue({
el:'.char_contain',//绑定事件名
data:{
carbrandList: data.data.carbrandList,//数据流
}
}));
})
.catch(function(err){
console.log(err);
});
});上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
通过JS如何实现文字间歇循环滚动效果
详细讲解React中的refs(详细教程)
使用tween.js实现缓动补间动画算法
二、vue前端抓包抓不上json
如果在Vue前端抓包时,无法抓取到JSON数据,可以考虑以下几种可能的原因和解决方法:
1. JSON数据被缓存:如果数据是通过Ajax请求获取并显示的,可能因为浏览器或服务器的缓存机制导致数据没有及时更新。可以尝试在请求URL后面添加随机数或时间戳等参数,使每次请求都不同,以避免缓存问题。
2.数据来源存在跨域访问限制:由于浏览器的同源策略限制,无法从其他域名的服务器上获取数据。可以使用JSONP方式、CORS(跨域资源共享)或者代理服务器等技术来实现跨域访问。
3.网络请求失败或数据格式错误:在发送请求时,可能会出现网络连接故障、服务器响应超时等问题,导致无法获取数据。此外,如果JSON数据格式错误,也可能会导致解析失败。可以通过浏览器的开发工具或者第三方的抓包工具查看网络请求状态和数据格式等信息。
4. Vue组件渲染问题:如果Vue组件没有正确渲染或者绑定数据,也可能会导致无法显示JSON数据。可以检查Vue组件的代码逻辑和数据绑定情况,确保数据能够正确地传递和显示。
需要注意的是,在进行前端开发时,还需要遵守相关的网络协议和数据传输规范,确保数据的安全*和合法*。同时还需要进行充分的测试和验证,以确保代码的质量和稳定*。
三、怎样使用VUE减少对服务器的请求次数
这次给大家带来怎样使用VUE减少对服务器的请求次数,使用VUE减少对服务器的请求次数的注意事项有哪些,下面就是实战案例,一起来看一下。
下面看下通过vue提供的keep-alive减少对服务器的请求次数
VUE2.0中提供了一个keep-alive方法,可以用来缓存组件,避免多次加载相应的组件,减少*能的消耗。比如,一个页面的数据包括图片、文字等用户都已经加载完了,然后用户通过跳转到了另外一个界面。然后从另外一个界面通过返回又回到了原先的界面。如果没有设置的话,那么原先界面的信息就要重新向服务器请求得到。而通过vue提供的keep-alive可以是页面的已经请求的数据得以保存,减少请求的次数,提高用户的体验程度。
缓存组件又分为两种,缓存整个站点的页面的组件或者缓存部分页面的组件。
1、缓存所有的页面,适用于每个页面都有请求的情况。方法如下,在需要缓存的router-view用keep-alive标签进行包裹起来。
<keep-alive>
<router-view></router-view>
</keep-alive>将首次触发请求写到created钩子里边,就能实现缓存。比如从列表页,去了详情页,回来还是原来的页面。
2、缓存部分组件或者页面,使用router.meta这个属*通过判断的方法可以实现。方法如下:
<keep-alive v-if="$route.meta.keepAlive">
<router-view></router-view>
</keep-alive>
<router-view v-if="!$route.meta.keepAlive"></router-view> router设置如下:
routers:[
{ path:'/home',
name: home,
meta:{keepAlive: true}//设置为true表示需要缓存,不设置或者false表示不需要缓存}
]还可以通过新增的属*include/exclude来设置。见名思意,include包含的意思,exclude除了的意思。这里需要用到组件的名称即name来进行设置,所以name肯定就要加上了。加入 a,b组件需要缓存,c,d组件不需要缓存。写法如下:
<keep-alive include="a,b">
<ponent></ponent>
</keep-alive>
<keep-alive exclude="c,d">
<ponent></ponent>
</keep-alive> vue项目的优化还可以通过组件的按需加载来实现,就像图片的懒加载一样,如果客户根本就没有看到那些图片,而我们却在打开页面的时候全部给加载完了,这样会大大的增加请求的时间,降低用户的体验程度。懒加载在很多的网站都有用到,比如淘宝、京东等等这样的购物网站,上面的图片等等都很多,如果你把滚轴迅速的往下拉的时候,你可能会看到图片加载的情况。
补充:
Vue路由开启keep-alive时的注意点
这个不是业务的要求,但是看到每次进入页面就重新渲染DOM然后再获取数据更新DOM,觉得作为一个前端工程师有必要优化下的加载逻辑,正好vue提供了 keep-alive的功能,所以就试用了下。当然,干任何事儿都不会一帆风顺的,在路上的磕磕碰碰在所难免,故在此记录下遇到的问题,希望看到这篇文章的人能有所帮助。ps:这个也没多难。
HTML部分:
<template>
<p class="">
<keep-alive>
<router-view></router-view>
</keep-alive>
</p>
</template>J*aScript部分:
.....
created: function(){
console.log(1)
},
mounted: function(){
console.log(2)
},
activated: function(){
console.log(3)
},
deactivated: function(){
console.log(4)
}.....1.什么阶段获取数据
页面生命周期钩子如上面的代码所示,这四个是最常用到的部分。这部分需要注意下,当引入keep-alive的时候,页面第一次进入,钩子的触发顺序created-> mounted-> activated,退出时触发deactivated。当再次进入(前进或者后退)时,只触发activated。
我们知道 keep-alive之后页面模板第一次初始化解析变成HTML片段后,再次进入就不在重新解析而是读取内存中的数据,即,只有当数据变化时,才使用VirtualDOM进行diff更新。故,页面进入的数据获取应该在activated中也放一份。数据完毕手动操作DOM的部分也应该在activated中执行才会生效。
所以,应该activated中留一份数据获取的代码,或者不要created部分,将created中的代码转移到activated中。
2.$route中的数据读不到
以前的写法是在data中将需要的$route数据进行赋值,便于其余方法使用,但是使用了 keep-alive后数据需要进入页面在activated中再次获取,才能达到更新的目的。定义一个initData方法,然后在activated中启动。
initData: function(){
let _this= this;
_this.fromLocation= JSON.parse(this.$route.query.fromLocation);
_this.toLocation= JSON.parse(this.$route.query.toLocation);
_this.activeIndex= parseInt(this.$route.params.activeIndex)|| 0;
_this.policyType= parseInt(this.$route.params.policyType)|| 0;
}, 3.当页动态修改url
需求描述:当页面在进行轮播操作的时候希望能记录当前显示的轮播ID(activeIndex)。当进入下一个页面再返回的时候能记住之前的选择,将轮播打到之前的ID位置。所以我想将这部分信息固化在url中,轮播发生变化时,修改URL。这样实现比较符最小修改原则,其余页面不用变动。
之前的写法是将activeIndex放在$route的query中,当轮播后,将
activeIndex的值存入$route.query.activeIndex中,然后$router.replace当前路由,理论上应该能发生变化,但实际没有。
查看文档后说,$route是只读模式。当然,对象部分是他监管不到的,我修改了并不是正统的做法。
神奇的地方来了:当我将activeIndex记在params中,轮播变动修改params中的参数,然后$router.replace当前路由,却能发生对应的变化。代码如下:
let swiperInstance= new Swiper('#swiper',{
pagination:'.swiper-pagination',
paginationClickable: false,
initialSlide: activeIndex,
onSlideChangeEnd: function(swiper){
let _activeIndex= swiper.activeIndex;
_this.$route.params.activeIndex= _activeIndex;
//$router我放到了window上方便调用
window.$router.replace({
name: _this.$route.name,
params: _this.$route.params,
query: _this.$route.query
});
//根据activeIndex,在这里初始化下面显示的数据
_this.transferDetail= _this.allData.plans[_activeIndex].segments;
_this.clearBusDetailFoldState();
}
});4.事件如何处理
估计你也能猜到,发生的问题是事件绑定了很多次,比如上传input监听change事件,突然显示了多张相同图片的问题。
也就是说,DOM在编译后就缓存在内容中了,如果再次进入还再进行事件绑定初始化则就会发生这个问题。
解决办法:在mounted中绑定事件,因为这个只执行一次,并且DOM已准备好。如果插件绑定后还要再执行一下事件的handler函数的话,那就提取出来,放在activated中执行。比如:根据输入内容自动增长textarea的高度,这部分需要监听textarea的input和change事件,并且页面进入后还要再次执行一次handler函数,更新textarea高度(避免上次输入的影响)。
5.地图组件处理
想必这是使用 keep-alive最的*能表现。之前是进入地图页面后进行地图渲染+线路标记;现在是清除以前的线路标记绘制新的线路,*能优化可想而知!
我这里使用的是高德地图,在mounted中初始化map,代码示例如下:
export default{
name:'transferMap',
data: function(){
return{
map: null,
}
},
methods:{
initData: function(){},
searchTransfer: function(type){},
//地图渲染这个在transfer-map.html中使用
renderTransferMap: function(transferMap){}
},
mounted: function(){
this.map= new AMap.Map("container",{
showBuildingBlock: true,
animateEnable: true,
resizeEnable: true,
zoom: 12//地图显示的缩放级别
});
},
activated: function(){
let _this= this;
_this.initData();
//设置title
setDocumentTitle('换乘地图');
_this.searchTransfer(_this.policyType).then(function(result){
//数据加载完成
//换乘地图页面
let transferMap= result.plans[_this.activeIndex];
transferMap.origin= result.origin;
transferMap.destination= result.destination;
//填数据
_this.transferMap= transferMap;
//地图渲染
_this.renderTransferMap(transferMap);
});
},
deactivated: function(){
//清理地图之前的标记
this.map.clearMap();
},
}6. document.title修改
这个不是 keep-alive的问题,不过我也在这里分享下。
问题是,使用下面这段方法,可以修改Title,但是页面来回切换多次后就不生效了,我也不知道为啥,放到setTimeout中就不执行。
document.title='页面名称';下面是使用2种环境的修复方法:
纯js实现
function setDocumentTitle(title){
"use strict";
//以下代码可以解决以上问题,不依赖jq
setTimeout(function(){
//利用iframe的onload事件刷新页面
document.title= title;
var iframe= document.createElement('iframe');
iframe.src='/f*icon.ico';//必须
iframe.style.visibility='hidden';
iframe.style.width='1*';
iframe.style.height='1*';
iframe.onload= function(){
setTimeout(function(){
document.body.removeChild(iframe);
}, 0);
};
document.body.endChild(iframe);
}, 0);
}jQuery/Zepto实现
function setDocumentTitle(title){
//需要jQuery
var$body=$('body');
document.title= title;
// hack在等webview中无法修改document.title的情况
var$iframe=$('<iframe src="/f*icon.ico"></iframe>');
$iframe.on('load', function(){
setTimeout(function(){
$iframe.off('load').remove();
}, 0);
}).endTo($body);
}
相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!
推荐阅读:
JSON格式的数据如何提交到服务端
JS动态加载时重复绑定如何处理
Angular父组件怎么调用子组件