欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue項目如何通過url鏈接引入其他系統(tǒng)頁面

 更新時間:2023年03月10日 10:07:55   作者:清云青云  
這篇文章主要介紹了vue項目如何通過url鏈接引入其他系統(tǒng)頁面問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue通過url鏈接引入其他系統(tǒng)頁面

1.正常配置菜單

在vue頁面使用iframe進(jìn)行嵌套加載其它系統(tǒng)的頁面,已加載百度為例

<template>
  <div id="app">
      <iframe
         style="border:none"
         :width="searchTableWidth"
         :height="searchTableHeight"
         v-bind:src="reportUrl"
       ></iframe>
  </div>
</template>
<script>
import Vue from 'vue'
export default {
  methods: {
    widthHeight() {
      this.searchTableHeight = window.innerHeight -180;
      this.searchTableWidth = window.innerWidth - 230
    },
  },
  data() {
    return {
      reportUrl: 'https://www.baidu.com/',
      searchTableHeight: 0,
      searchTableWidth: 0
    }
  },
   mounted() {
    window.onresize = () => {
      this.widthHeight(); // 自適應(yīng)高寬度
    };
    this.$nextTick(function () {
      this.widthHeight();
    });
  },
  created() {
    // 從路由里動態(tài)獲取 url地址   具體地址看libs下util.js里的 backendMenuToRoute  方法 
    this.reportUrl = 'https://www.baidu.com/'
  },
  watch: {
    '$route': function () {
      // 監(jiān)聽路由變化
      this.reportUrl =  'https://www.baidu.com/'
    }
  }
}
</script>

效果圖:

2.加載引入系統(tǒng)可能會出現(xiàn)攔截

xxx 拒絕了我們的連接請求。

前端頁面Refused to display 'xxx' in a frame because it set 'X-Frame-Options' to 'sameorigin',對于這個問題我們需要在引入的項目中進(jìn)行攔截處理,引入項目中response.addHeader("x-frame-options","SAMEORIGIN")需要改寫為response.addHeader("x-frame-options","ALLOW-FROM http://127.0.0.1:項目端口/");對訪問方式進(jìn)行允許iframe不同域名之間進(jìn)行調(diào)動

3.引入項目的后臺攔截代碼

@Configuration
public class MvcConfig implements WebMvcConfigurer {
? ?//配置日志
? ? private static final Logger logger= LoggerFactory.getLogger(MvcConfig.class);
? ??
? ? @Autowired
? ? SystemConfig systemConfig;
? ?
? ? @Override
? ? public void addInterceptors(InterceptorRegistry registry) {
? ? ? ? registry.addInterceptor(new HandlerInterceptor() {
? ? ? ? ? ? @Override
? ? ? ? ? ? public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
? ? ? ? ? ? ? ? //設(shè)置日志級別
? ? ? ? ? ? ? ? //logger.debug("前置方法被執(zhí)行");
? ? ? ? ? ? ? ? return true;
? ? ? ? ? ? }
?
? ? ? ? ? ? @Override
? ? ? ? ? ? public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
? ? ? ? ? ? ? ? //logger.info("后置方法被執(zhí)行");
? ? ? ? ? ? ? ? //System.out.println(systemConfig.getMqiUrl());
? ? ? ? ? ? ?? ?if(null == modelAndView){
? ? ? ? ?? ??? ??? ?return;
? ? ? ? ?? ??? ?}
? ? ? ? ? ? ?? ?response.addHeader("x-frame-options","ALLOW-FROM http://127.0.0.1:8004/");

? ? ? ? ? ? ? ? modelAndView.getModelMap().addAttribute("arcgisserviceUrl", systemConfig.getArcgisserviceUrl());
? ? ? ? ? ? }
?
? ? ? ? ? ? @Override
? ? ? ? ? ? public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
? ? ? ? ? ? ? ? //logger.debug("最終方法被執(zhí)行");
? ? ? ? ? ? }
? ? ? ? });
? ? }
}

vue頁面嵌套外部url

我的需求是一進(jìn)入頁面通過調(diào)接口獲取頁面的url,然后把url嵌套到當(dāng)前頁面。

<template>
  <div class="page-content" id="bi-div"></div>
</template>

<script>
  import reportFormApi from '@/api/reportForm'
  
  export default {
    name: 'reportComponent',
    props:{
      codeStr:String
    },
    data () {
      return {
        urlCode :"",
      }
    },
    mounted: function () {
      if(this.codeStr){
        this.urlCode = this.codeStr;
        this.getUrl();
      }
    },
    methods: {
      getUrl(){
        reportFormApi.getQuickBi({url : "/postUrl/" + this.urlCode}).then(res=>{
          if(res.code==0){
            var frame = '<iframe frameborder="no" border="0" marginwidth="0" marginheight="0" scrolling="no" width="100%" height="100%" src="' + res.data.previewUrl + '"></iframe>';
            var newNode = document.createElement('div');
            newNode.innerHTML = frame;
            newNode.style.height = '1200px';
            var htmlBody = document.getElementById('bi-div');
            htmlBody.insertBefore(newNode, htmlBody.firstChild);
          }else{
            this.$Message.error({
              content: res.message,
              duration: 2.5,
              closable:true,
            });
          }
        })
      }
    }
  }
</script>

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論