经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » Vue.js » 查看文章
Vue中代码传送(teleport)的实现
来源:jb51  时间:2023/4/19 9:01:05  对本文有异议

代码传送是啥

在Vue中,代码传送就是将某部分的代码从Vue的template标签下传送到指定的地方,这个地方通常是body标签下。在使用Vue编写界面时,我们都是在html的Body中写一个div,然后指定一个id,然后在Vue的实例中的template中写我们的界面代码,然后由Vue来帮我们将templte中的dom元素渲染到界面上。如下所示:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. ...
  5. </head>
  6. <body>
  7. <div id="root"></div>
  8. </body>
  9. <script>
  10.  
  11. const app = Vue.createApp({
  12. template:
  13. `
  14. <div>
  15. ...界面描述
  16. </div>
  17. `
  18. });
  19.  
  20. const vm = app.mount('#root');
  21. </script>

从上面的代码可知,我们在Vue实例的template标签中渲染的dom元素都会挂载到body中的id为root的div下面,如下图:

这样本来已经能够完成大部分界面描述需求了,但是有种场景需要我们去解决,那就是比如我们删除一个内容时,为了防止是用户的误触,会弹出一个对话框,然后对话框背后会有一个铺满整个窗口的蒙层。假设我们的展示内容的div很小,这时蒙层就只能展示到我们当前的div中,如下图:

点击显示蒙层的按钮后:

我们发现,这个蒙层无法覆盖所有窗口的区域,这很明显是不符合需求,因为我们所有的界面代码都会被挂载到body标签中的id="root"的div中,如果这个div下的界面的大小被固定了,那么蒙层的大小就会被限制,蒙层的做法我们最好放到body标签中,这样蒙层就不会收到父DIV的大小限制了。那我们的代码都是在template中编写的,如何将其传送到body标签下呢,这就是本文的内容teleport.

实例解析

为了展示Vue传送的例子,我们在界面的中心写了一个绿色的块,代表我们的UI,有一个按钮,点击后显示蒙层。如下图所示:

这个需求就可以使用代码传送的技术实现,代码如下:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  6. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  7. <title>传送门</title>
  8. <style>
  9. .area{
  10. position: absolute;
  11. left: 50%;
  12. top: 50%;
  13. transform: translate(-50%,-50%);
  14. width: 200px;
  15. height: 300px;
  16. background: green;
  17. }
  18.  
  19. .mask{
  20. position: absolute;
  21. left: 0;
  22. top: 0;
  23. right: 0;
  24. bottom: 0;
  25. background: #000;
  26. opacity: 0.5;
  27. color: #ffff;
  28. font-size: 100px;
  29. }
  30. </style>
  31. <script src="https://unpkg.com/vue@next"></script>
  32. </head>
  33. <body>
  34. <div id="root"></div>
  35. <div id="hello"></div>
  36. </body>
  37. <script>
  38.  
  39. const app = Vue.createApp({
  40. data(){
  41. return{
  42. show:false,
  43. message:'hello world'
  44. }
  45. },
  46. methods:{
  47. handleClick(){
  48. this.show = !this.show;
  49. }
  50. },
  51. template:
  52. `
  53. <div class="area">
  54. <button @click="handleClick">点击显示蒙层</button>
  55. <teleport to="#hello">
  56. <div class="mask" v-show="show">
  57. {{message}}
  58. <div>海塔灯</div>
  59. </div>
  60. </teleport>
  61. </div>
  62. `
  63. });
  64.  
  65. const vm = app.mount('#root');
  66. </script>

运行结果:

我们可以看到,在template下定义的蒙层代码就被传送到body标签下了,传送代码的实现也很简单,就是使用

  1. <teleport to="#hello">要传送的内容</teleport>

在teleport标签上,可以是用to="标签或者是id",假设要传送到body下,就使用to="body",要传送到指定的id对应的div下就使用 to="#id名称"的形式

到此这篇关于Vue中代码传送(teleport)的实现的文章就介绍到这了,更多相关Vue 代码传送内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号