91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue項目嵌入jsp頁面的方法

發布時間:2020-06-16 11:53:48 來源:億速云 閱讀:421 作者:鴿子 欄目:web開發

vue項目怎么嵌入jsp頁面?下面本篇文章給大家介紹一下在vue項目中嵌入jsp頁面的方法,文中通過示例代碼介紹的非常詳細。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

vue項目嵌入jsp頁面的方法

在vue 項目中嵌入jsp頁面

今日一個項目中一塊功能模塊是其他系統使用jsp已經開發好的頁面,想著直接將其嵌入到當前的vue項目中節約開發成本;但是發現并非想象的那么簡單

創建一個server.vue組件加載jsp頁面

1 、第一種(使用 v-html進行jsp 渲染)

server.vue

<template>
  <div class="docker-server">
    <div v-html="pageContent"></div>
  </div>
</template>

<script type="text/ecmascript-6">
    export default {
        name: "server",
      data(){
          return{
            pageContent:'',
          }
      },
      created(){
           this.getDockerPage();
      },
      methods:{
        getDockerPage() {

          // $post為全局的axios post請求對象;dockerMange 為后端ip
          let url = `${api_config.dockerMange}/core/funcs/system/docker/server/index.jsp`;
          this.$post(url).then(res => {
            console.log(res);
           this.pageContent = res.data;
          }).catch(err => {
            console.log(err)
          });
        }
      }
    }
</script>

<style scoped>

</style>

請求返回的jsp數據格式

vue項目嵌入jsp頁面的方法

后臺返回的 index.jsp 內容如下:

<!DOCTYPE html>
<script type="text/javascript">
/** 常量定義 **/
var TDJSCONST = {
  YES: 1,
  NO: 0
};
/** 變量定義 **/
var contextPath = "/docker";
var imgPath = "/docker/core/styles/style1/img";
var ssoUrlGPower = "";
var limitUploadFiles = "jsp,java,jspx,exe"
var signFileServiceUrl = http://**/BjfaoWeb/TitleSign";
var isOnlineEval = "0";
var useSearchFunc = "1";
var maxUploadSize = 500;
var isDev = "0";
var ostheme = "1";
</script>

<html style="overflow: hidden;">
<head>
    <title>Docker容器服務器管理</title>  <!-- http://** 我為保護服務ip 而手動更改了 -->
    <link rel="stylesheet" href="http://**/docker/core/styles/style1/css/views.css" type="text/css"/>
    <link rel="stylesheet" href="http://**/docker/core/styles/style1/css/cmp/tab.css" type="text/css"/>
    <link rel="stylesheet" href=http://**/docker/dist/css/common.css">
    <link rel="stylesheet" href="http://**/dist/css/iconfont.css">
    <script type="text/Javascript" src=http://**/docker/core/js/datastructs.js"></script>
    <script type="text/Javascript" src="http://**/docker/core/js/sys.js"></script>
    <script type="text/Javascript" src="http://**/docker/core/js/prototype.js"></script>
    <script type="text/Javascript" src="http://**/docker/core/js/smartclient.js"></script>
    <script type="text/Javascript" src="http://**/docker/core/js/cmp/tab.js"></script>
    <script type="text/javascript">
        function doInit() {
            var tabArray = [{
                title: "容器服務器管理",
                content: "",
                contentUrl: "http://**/docker/core/funcs/system/docker/server/manage.jsp",
                imgUrl: "http://**" + imgPath + "/cmp/tab/sys_config.gif",
                useIframe: true
                },
                {
                    title: "新增容器服務器",
                    content: "",
                    contentUrl: "http://**/docker/core/funcs/system/docker/server/edit.jsp",
                    imgUrl: "http://**" + imgPath + "/cmp/tab/sys_config.gif",
                    useIframe: true
                }];
            buildTab(tabArray, 'contentDiv');
        }
    </script>
</head>
<body onload="doInit();">
<div id="contentDiv"></div>
</body>
</html>

頁面顯示如下:

vue項目嵌入jsp頁面的方法

因:jsp頁面只是寫了幾個標簽,其他數據都是通過外部js中的方法動態渲染出來的,然而使用v-html只是將jsp 頁面加載到了當前頁面上,但是沒有將js 再次load進來;所以頁面上就只有幾個沒有用的標簽!最終確認這種方法不可行

2、 第二種(使用 iframe 進行jsp嵌入)

修改后的 server.vue

<template>
  <div class="docker-server">
    <iframe  name = "iframeChild" id = "iframeChild" v-bind:src="getPageUrl"
            width="100%" :height="iframeHeight"
            frameborder="0" scrolling="no" ref="iframeDom"
    ></iframe>
  </div>
</template>

<script type="text/ecmascript-6">
    export default {
        name: "server",
      data(){
          return{
            iframeHeight:500,
            getPageUrl:`${api_config.dockerMange}/core/funcs/system/docker/server/index.jsp?MySessionId=${JSON.parse(sessionStorage.getItem("userInfo")).userToken}`
          }
      },
      mounted: function () {
        this.$nextTick(() => {
          if(this.$refs.iframeDom)
            this.iframeHeight = window.innerHeight - this.$refs.iframeDom.$el.offsetTop;
        })
      },
    }
</script>

<style scoped>

</style>

這次終于對了運行效果如下:

vue項目嵌入jsp頁面的方法

還是老式的方法過的奧,測試證明這種方式可行,完美解決問題

以上就是vue項目嵌入jsp頁面的方法介紹,更多請關注億速云其它相關文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

岱山县| 荥经县| 元朗区| 民权县| 马尔康县| 大埔县| 嘉祥县| 秦皇岛市| 阿拉善左旗| 海兴县| 马尔康县| 金坛市| 西盟| 三明市| 陵水| 依安县| 宁强县| 沈阳市| 溆浦县| 永登县| 阳春市| 清涧县| 鸡泽县| 延吉市| 高州市| 茶陵县| 沙坪坝区| 华池县| 普定县| 合阳县| 铜梁县| 岑巩县| 微山县| 宿松县| 宁河县| 神池县| 泸定县| 木兰县| 兴义市| 和林格尔县| 滦南县|