【问题标题】:How to change the css inside a @media print query?如何更改 @media 打印查询中的 css?
【发布时间】:2018-02-22 11:12:28
【问题描述】:

当 div 的内容太大时,我需要在打印之前对其进行缩放。我已经按照这里的有用建议设置了打印样式表。当需要打印时,我发现我需要更改 @media 打印查询中的一些 css。我发现一个常规的 CSS 选择器不是在媒体查询中更改类,而是对屏幕上的 div 进行更改,而不是在打印查询中。是否有一个选择器可用于仅对 @media 打印 css 进行更改?

此处的示例:点击“更改比例”按钮会立即缩放图像。我希望更改后的比例仅适用于打印输出。

var canvas = document.getElementById("canvas1");
function draw_a() {
  var context = canvas.getContext("2d");
//   //  LEVER

//plane
context.fillStyle   = '#aaa';
context.fillRect  (25, 90, 2500, 400);


}




function changeScale() {
  
  var scale = .1;
  
  console.log("scale:" + scale);
  
   $('.myDivToPrint').css({
                '-webkit-transform': 'scale(' + scale + ')',
                '-moz-transform': 'scale(' + scale + ')',
                '-ms-transform': 'scale(' + scale + ')',
                '-o-transform': 'scale(' + scale + ')',
                'transform': 'scale(' + scale + ')',
             
            });

}

$(document).ready(function(){
  draw_a();
  
});
div.sizePage {
  color: #333;
}

canvas {
  border: 1px dotted;
}

.printOnly {
  display: none;
}

@media print {
  html,
  body {
    height: 100%;
    background-color: yellow;
  }
  .myDivToPrint {
    background-color: yellow;
    top: 0;
    left: 0;
    margin: 0;
  }
  .no-print,
  .no-print * {
    display: none !important;
  }
  .printOnly {
    display: block;
  }
}

@media print and (-ms-high-contrast: active) and (-ms-high-contrast: none) {
  html,
  body {
    height: 100%;
    background-color: pink;
  }
  .myDivToPrint {
    background-color: yellow;
    /*
  -moz-transform: rotate(90deg) scale(0.3);
        -ms-transform: rotate(90deg) scale(0.3);
        -o-transform: rotate(90deg) scale(0.3);
        -webkit-transform: rotate(90deg) scale(0.3);
        transform: rotate(90deg) scale(0.3); /* Standard Property */
        position: fixed;
    top: 0;
    left: 0;
    margin: 0;
    padding: 15px;
    font-size: 14px;
    line-height: 18px;
    position: absolute;
    display: flex;
    align-items: center;
    justify-content: center;
    /*
    -webkit-transform: rotate(90deg);
    -moz-transform: rotate(90deg);
    -o-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
 */
  
  }
  .no-print,
  .no-print * {
    display: none !important;
  }
  .printOnly {
    display: block;
  }
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<button onclick="window.print();" class="no-print">Print Canvas</button>
<button onclick="changeScale();" class="no-print>">Change Scale</button>
<div class="myDivToPrint">
<canvas height="2500px" width="4000px" id="canvas1"></canvas>
</div>

谢谢, 马特

【问题讨论】:

  • 我不确定我是否理解。 @media print 查询中的选择器已仅适用于打印。好像你已经做了你需要的。你能澄清一下吗?
  • 在代码 sn-p 中,当单击“更改比例”按钮时,您可以看到屏幕上的图像实际更改了比例。这向我表明浏览器创建了一些其他类(可能是一个元素)并将其应用于屏幕上的 div。媒体查询中的实际类保持不变。我会尝试更新问题。

标签: javascript jquery html css printing


【解决方案1】:

如果我理解正确的话。您想编辑媒体查询本身。在这种情况下,这里有几个例子。 jQuery change media query width value

$('body').append("<style type='text/css'>@media screen and (min-width: 500px) { /*whatever*/ }</style>");

您也可以使用 window.MatchMedia() ,如下面的示例所示! https://codepen.io/ravenous/pen/BgGKA

您可以只更新现有元素(或创建一个)textContent 以包含规则,这将使其在给定上下文中有效。 Generating CSS media queries with javascript or jQuery

document.querySelector('style').textContent +=
    "@media screen and (min-width:400px) { div { color: red; }}"

还有一个库允许混合使用专门用于此目的的 CSS 和 jQuery。 http://www.learningjquery.com/2017/03/how-to-use-media-queries-with-jquery

【讨论】:

  • 这些看起来很有希望。我正在尝试修改实现一个的代码 sn-p 并且到目前为止失败。你能创建一个代码 sn-p 来展示它是如何工作的吗?谢谢,马特
  • if( 条件) { document.querySelector('style').textContent += "@media print { div { color: red; }}"; }
  • 请接受答案! :) 其中任何一种都可以,但请记住 SO 仅供参考!
猜你喜欢
  • 1970-01-01
  • 2013-12-16
  • 1970-01-01
  • 2013-04-01
  • 1970-01-01
  • 2017-04-16
  • 2010-12-13
  • 2018-08-09
  • 1970-01-01
相关资源
最近更新 更多