整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

在HTML页面中嵌入其他页面的方法-零基础自学网页制作

HTML页面中嵌入其他页面的方法

在自己的页面中嵌入其他页面是一个非常重要的操作,既能丰富自己的页面样式又能增强页面的信息量。

举个例子,如果打算在自己的页面中插入一个视频网站的视频该怎么做呢?

假如我现在自己的页面中嵌入这个视频,

我只需要在视频下侧找到"分享"。

点击之后出现这样的对话框,如图:

通过在我们的页面中粘贴这段通用代码就可以显示这个视频了。

代码如下:

<iframe height=498 width=510 src='http://player.youku.com/embed/XNDQ5Mjg1MTU1Mg==' frameborder=0 'allowfullscreen'></iframe>

下面就写到我们的页面中试试吧。

首先复制"第一个网页.html"文件,改名为"在页面中嵌入页面.html"保存,然后用记事本打开,修改<head></head>标签中的<title>第一个页面</title>编辑为"在页面中嵌入页面"即可,完整代码如下:

<!DOCTYPE HTML>
  <html>
  <head> 
  <title>在页面中嵌入页面</title>
  </head> 
  <body>
  <iframe height=498 width=510 src='http://player.youku.com/embed/XNDQ5Mjg1MTU1Mg==' frameborder=0 'allowfullscreen'></iframe>
  </body>
  </html>

页面效果如下:

怎么样,是不是很神奇!

下面我们来分析一下这段代码的含义。

首先要引入一个新标签<iframe>,HTML的使用手册中翻译为"框架",说实话,这么翻译初学者是不知所云的。这个框架元素的主要作用就是在自己的页面中嵌入其他页面。

在<iframe>标签中先指定路径属性即src。这里使用的是单引号,实际上只要是半角符号,单引号和双引号都可以的。

然后设置长宽属性,即width和height,大家可以尝试改变数据看看。

frameborder可以为iframe的窗口指定一个边框,大家可以尝试把0改成1看看。大家注意哈,这里输入30和输入1是一样的,因为这个属性不是定义边框的宽度,而是定义是否显示边框!在编程中叫做布尔值,0代表没有边框,1代表有边框!和我们点灯的开关一样!

如图:多了个边框出来。

最后'allowfullscreen'这个描述非常的奇葩,把它删掉没有任何影响。不晓得是干什么的,主要是也不符合html的语法(也可能是我没见识)。如果有详细了解的小伙伴欢迎留言指教,感激不尽。

下面我们尝试修改一下src属性,给它一个别的路径看看。例如:

<!DOCTYPE HTML>
  <html>
  <head> 
  <title>在页面中嵌入页面</title>
  </head> 
  <body>
  <iframe height=498 width=510 src='https://www.toutiao.com/i6790673377188119052/'>
  </iframe>
  </body>
  </html>

需要注意的是,修改了src并保存文件之后要把原页面关闭然后重新打开才可以正常显示!

效果如下:

在浏览网页时我们还经常遇到这样的情况,就是有一个独立窗口显示嵌套的页面,上面有个标题,一点击就会跳到那个嵌入的页面上,这个其实很简答,使用一个<a></a>元素即可办到,示例代码如下:

<a href="https://www.toutiao.com/i6790673377188119052/">HTML中的块级元素与内联元素——零基础自学网页制作</a>
<iframe height=498 width=510 src='https://www.toutiao.com/i6790673377188119052/'></iframe>

页面示例如下:

框架元素并没有换行,所有我们可以推测出<iframe>标签实际上是个内联元素,如何让它换行呢?

为<iframe>的style属性中写入display:block即可。这句代码的意思是按照块元素来显示<iframe>内容。

示例代码如下:

<iframe height=498 width=510 style = "display:block;"src='https://www.toutiao.com/i6790673377188119052/'></iframe>

页面效果如下:

是不是很有意思。

下面我们来介绍一个更有趣的玩法。如图所示:

这个怎么做呢?

这就要介绍<iframe>标签中的另一个属性:name(名字)

示例代码如下:name="iframe"

<iframe name = "iframe" height=498 width=510style = "display:block;"src='https://www.toutiao.com/i6790673377188119052/'allowfullscreen'></iframe>

这里讲个题外话,如果大家了解中国古代的"请神术"的话就会知道这样一个有趣的传说,就是如果我们能叫出鬼神的名字就可以驱使它。

编程也是这样,我们给函数或变量一个名字后,就可以随时随地的驱使它。

现在我们给<iframe>起了个名字叫做"iframe",当然您可以使用其他名字也没问题,但要使用英文或汉语拼音命名,名字是英语字母组合最好。

有了名字之后,<a>标签就要驱使<iframe>标签来显示自己路径下的内容,如何驱使呢?

大家还记得<a>标签中有一个target属性吗?只要让target="iframename"即可!

也就是target="iframe"。示例代码如下:大家要注意的是<a>标签也是内联元素,也需要添加display:block,不然也是排在一列显示。

<a style = "display:block;" target="iframe" href="https://www.toutiao.com/i6790673377188119052/">HTML中的块级元素与内联元素——零基础自学网页制作</a><!--第一个a链接的是头条文章-->
<a style = "display:block;" target="iframe" href="https://baike.baidu.com/item/%E6%AD%BC-20/1555348?fromtitle=%E6%AD%BC20&fromid=1838467&fr=aladdin"> 歼20战斗机百科</a><!--第二个a链接的是百度百科-->
<a style = "display:block;"target="iframe" href="image1.jpg">IT美女</a><!--第三个a链接的是本地图片-->
<iframe name = "iframe" height=498 width=510style = "display:block;"></iframe>

只要我们为不同的<a>标签赋予target="iframe"的属性,点击这些<a>标签就可以在叫做"iframe"的框架元素中显示自己的页面。这时我们可以把<iframe>标签中的src属性删除掉,保存文件后,关闭测试网页,再重新打开,效果如下:

初始状态下,因为框架元素中的src是空的,所以打开后是空白的。如果您觉得单调可以任意复制3个<a>中的一个href中的链接路径给<iframe>的src属性,打开就是相应的标签。这个就不演示了,大家自己试试即可。

点击第一个链接效果如下:

点击第二个链接如下:

点击第三个链接如下:

最后再强调一下,改完框架的src属性后需要关闭页面后重新打开才可以,刷新的话并不能正确显示!切记!

今天的示例代码如下:

<!DOCTYPE HTML>
  <html>
  <head> 
  <title>在页面中嵌入页面</title>
  </head> 
  <body>
  <a style = "display:block;" target="iframe" href="https://www.toutiao.com/i6790673377188119052/">HTML中的块级元素与内联元素——零基础自学网页制作</a>
  <a style = "display:block;" target="iframe" href="https://baike.baidu.com/item/%E6%AD%BC-20/1555348?fromtitle=%E6%AD%BC20&fromid=1838467&fr=aladdin">歼20战斗机百科</a>
<a style = "display:block;" target="iframe" href="image1.jpg">IT美女</a>
<iframe name = "iframe" height=498 width=510 style = "display:block;"></iframe>
</body>
</html>

今天的内容结束了,明天我将会为大家介绍<object>和<embed>这两个标签,它们可以在页面中嵌入更多有趣的东西。

喜欢的小伙伴请关注我,阅读中遇到任何问题请给我留言,如有疏漏或错误欢迎大家斧正,不胜感激!

HTML完整学习目录

HTML序章(学习目的、对象、基本概念)——零基础自学网页制作

HTML是什么?——零基础自学网页制作

第一个HTML页面如何写?——零基础自学网页制作

HTML页面中head标签有啥用?——零基础自学网页制作

初识meta标签与SEO——零基础自学网页制作

HTML中的元素使用方法1——零基础自学网页制作

HTML中的元素使用方法2——零基础自学网页制作

HTML元素中的属性1——零基础自学网页制作

HTML元素中的属性2(路径详解)——零基础自学网页制作

使用HTML添加表格1(基本元素)——零基础自学网页制作

使用HTML添加表格2(表格头部与脚部)——零基础自学网页制作

使用HTML添加表格3(间距与颜色)——零基础自学网页制作

使用HTML添加表格4(行颜色与表格嵌套)——零基础自学网页制作

16进制颜色表示与RGB色彩模型——零基础自学网页制作

HTML中的块级元素与内联元素——零基础自学网页制作

初识HTML中的<div>块元素——零基础自学网页制作

在HTML页面中嵌入其他页面的方法——零基础自学网页制作

封闭在家学网页制作!为页面嵌入PDF文件——零基础自学网页制作

HTML表单元素初识1——零基础自学网页制作

HTML表单元素初识2——零基础自学网页制作

HTML表单3(下拉列表、多行文字输入)——零基础自学网页制作

HTML表单4(form的action、method属性)——零基础自学网页制作

HTML列表制作讲解——零基础自学网页制作

为HTML页面添加视频、音频的方法——零基础自学网页制作

音视频格式转换神器与html视频元素加字幕——零基础自学网页制作

HTML中使用<a>标签实现文本内链接——零基础自学网页制作

午接到博客访客的反馈,表示博客中的链接在原窗口打开的话,网站的体验非常的不好,而自己又懒的一个个去修改博客网页中的链接打开方式,就加了一个强制页面所有链接新窗口打开的代码,一招解决问题。

html页面强制所有链接新窗口打开的代码

<base target="_blank">

将此代码放到,网页中的 <head>标签之内即可实现,当前页面所有A链接新窗口打开

html <base> 标签

<base>:标签当前页面上的所有的相对链接规定默认 URL 或 默认目标。

语法:

<base href="网址" target="打开的方式">

属性;

herf:规定的默认链接

target:链接打开的方式,参数有 _blank,_self 等,与A标签的 target 属性相同

例:html页面所有链接强制新窗口打开

<base target="_blank">

例:html页面所有链接强制在当前窗口打开

<base target="_self">

例:设置默认的URL

<!DOCTYPE html>
<html lang="en">
<head>
 <base href="https://www.feiniaomy.com" target="_blank">
 <title>Document</title>
</head>
<body>
 <a href="/post/1.html">我是相对链接,我可以打开 https://www.feiniaomy.com/post/1.html</a>
 <a href="http://www.baidu.com">我是绝对链接,我可以打开 http://www.baidu.com</a>
</body>
</html>

<base> 标签使用注意事项

1、一个页面中,<base> 标签只能出现一次

2、<base> 标签只能在 <head></head>标签中出现

3、<base> 属于单标签,没有结束标签,类似 <img> 标签

由于项目需求将vue改造成多页面,简单记录下改造的过程,以及如何使用。

何使用项目

  1. git clone
  2. url克隆项目到本地
  3. 在src/pages文件夹下,所有的页面都在pages下编写,新建一个目录(开发项目名称)demo,在demo中新建一个demo.js,demo.html,demo.vue,router/index.js这是一个单独文件的所有文件,每一个目录相当于一个项目需求,是一个单独分开的页面,例如demo和sign活动
  4. 具体代码可参考文件中的sign和index目录。

项目改造过程

选型时考虑到多页面更合适目前项目,对新建项目进行改造,记录代码如下.

  1. vue-cli webpack 项目名称(安装项目)
  2. 修改文件build/utils.js,加入如下代码
// 多入口页面配置(读取pages下面文件夹下的js文件,js最好和目录文件名字一致)
exports.entries = function () { 
 let entryFiles = glob.sync(PAGE_PATH+'/*/*.js')
 let map = {}
 entryFiles.map((filePath) => {
 let filename = filePath.substring(filePath.lastIndexOf('\/')+1,filePath.lastIndexOf('.'))
 map[filename] = filePath
 })
 return map
} 
// 多页面输出配置,读取pages文件夹下对应的html文件,所以文件夹下的html文件最好也和文件目录名保持一致
exports.htmlPlugin = function(){
 let entryHtml = glob.sync(PAGE_PATH+'/*/*.html')
 let arr = []
 entryHtml.map((filePath) => {
 let filename = filePath.substring(filePath.lastIndexOf('\/')+1,filePath.lastIndexOf('.'))
 let conf = {
 template: filePath, // 模板来源
 filename: filename+'.html', // 模板名称
 chunks: ['manifest','vendor', filename], // 页面模板需要加对应的js,不加这一行每个页面都会引入所有的js
 inject: true
 }
 if(process.env.NODE_ENV == 'production'){
 conf = merge(conf,{
 minify: {
 removeComments: true,
 collapseWhitespace: true,
 removeAttributeQuotes: true
 },
 chunksSortMode: 'dependency'
 })
 }
 arr.push(new HtmlWebpackPlugin(conf))
 })
 return arr
}
  1. 修改build/webpack.dev.conf.js和build/webpack.prod.conf.js
plugins: [
//加上下面的一段代码
].concat(utils.htmlPlugin())
  1. 修改build/webpack.base.conf.js
entry: utils.entries(),
  1. 这样修改配置就完成了,访问通过类似/sign.html/#/访问(hash路由)
  2. 上面是使用hash路由方式访问地址,路由中有#号,在一些情况下是不太合适,例如,微信的分享中如果有#号,在分享的链接中在#号前面会加一些字符号,可能会影响页面的代码,这种情况下考虑使用路由的mode:'history'模式,这种情况下开发环境可以如下修改
devServer: {
 historyApiFallback: {
 rewrites: [
 { from: /\/index/, to: path.posix.join(config.dev.assetsPublicPath, 'index.html') },
 { from: /\/sign/, to: path.posix.join(config.dev.assetsPublicPath, 'sign.html') },
 { from: /\/test/, to: path.posix.join(config.dev.assetsPublicPath, 'test.html') },
 ],
 },,
 },

可以通过/sign,/test访问页面 7. 上面这种模式打包上线的时候需要后台的配置,(比如打包后的文件都在build文件夹下),nginx配置如下

server {

listen 3088;

server_name localhost;

#charset koi8-r;

#access_log /var/log/nginx/host.access.log main;

root /usr/share/nginx/html/build;

index index.html index.htm;

#error_page 404 /404.html;

# redirect server error pages to the static page /50x.html

#

error_page 500 502 503 504 /50x.html;

location = /50x.html {

root /usr/share/nginx/html;

}

location /sign {

try_files $uri $uri/ /sign.html;

}

location /test {

try_files $uri $uri/ /test.html;

}

}

上面的配置就能直接访问www.host:3388/sign,www.host:3388/test,这样整体的多页面配置就完成了。

通过node启动一个服务器来渲染多个html页面

直接在项目的目录下建立一个app.js安装相应的依赖,具体代码如下