0

我有一个 if 语句,用于检查 DOM 中显示的图像最初是否小于 600px 宽,如果是,则将图像调整为不同的宽度。但是它不起作用。正确的值会显示在警报中,但不会在下面的一行中传递给 CSS。知道为什么会发生这种情况吗?

jQuery

$('span.i_contact').each(function() {    
var imgWidth = parseInt($(this).data('image-width'));    
console.log(imgWidth)
if (imgWidth < 600) {
    var newWidth = ((imgWidth / 600) * 300)  
    alert(newWidth)
    $(this).css({
        "width":newWidth
    })    
}    
    var pos_width = ($(this).data('posWidth')) / 2.025;
    var pos_height = ($(this).data('posHeight')) / 2.025;
    var xpos = ($(this).data('posX')) / 2.025;
    var ypos = ($(this).data('posY')) / 2.025;
    var taggedNode = $('<div class="tagged" />')
    taggedNode.css({
        "border":"5px solid orange",
        "width":pos_width,
        "height":pos_height,
        "left":xpos,
        "top":ypos
    }); 
var n = $(this).data('index');
$('.i_tagmap' + n).append(taggedNode);   
});

$("span.o_contact").each(function() {        
var imgWidth = parseInt($(this).data('image-width'));
console.log(imgWidth)
if (imgWidth < 600) {
    var newWidth = ((imgWidth / 600) * 300);
    alert(newWidth)
    $(this).css({
        "width":newWidth
    });    
}    
    var pos_width = ($(this).data('posWidth')) / 2.025;
    var pos_height = ($(this).data('posHeight')) / 2.025;
    var xpos = ($(this).data('posX')) / 2.025;
    var ypos = ($(this).data('posY')) / 2.025;
    var taggedNode = $('<div class="tagged" />')
    taggedNode.css({
        "border":"5px solid green",
        "width":pos_width,
        "height":pos_height,
        "left":xpos,
        "top":ypos  
    });
var n = $(this).data('index');
$(this).append(taggedNode);       
});

ERB(如何生成图像)

<% n = steps.index(step) %>
<h2 style="margin-left:20px;"> Step <%= n + 1%></h2>
<div class="stepcontainer">
<div class="steptext">
    <%= step.instruction %>
</div>
<div class="modalbutton">
    <%= render(step.flags.new) %>   
</div>


<% if step.input_contact.present? %>
    <div class="productimg">
        <div class="image_panel<%= n %>" style="float:left; width:600px; position:relative;">   
            <span class="i_contact i_contact<%= n %>" data-pos-x="<%= step.i_connection.pos_x %>" data-pos-y="<%= step.i_connection.pos_y %>"  data-pos-width="<%= step.i_connection.pos_width %>" data-pos-height="<%= step.i_connection.pos_height %>" id="spanid<%= n %>" data-image-width="<%= step.i_connection.image.dimensions.first %>" data-index="<%= n %>"></span>   
            <%= link_to image_tag(step.i_connection.image.image.url(:medium), id: "iconnection#{n}" ), "#{step.i_connection.image.image.url(:large)}", class: "fancybox" %>
            <div class="i_tagmap<%= n %>"></div>    
        </div>      
    </div>

    <% if step.i_connection.cord? && !step.o_connection.dongle? %>
        <div class="cableimg">
            <%= image_tag(step.i_connection.cord_type.image.url(:thumb), :class => "orange")  %>
        </div>
    <% end %>           
<% end %>   <!-- end of step.input_contact.present -->

<% if step.o_connection.cord? && !step.o_connection.dongle? %>
    <div class="cableimg">
        <%= image_tag(step.o_connection.cord_type.image.url(:thumb), :class => "green") %>
    </div>      
<% end %>
<div class="productimg">
    <div class="image_panel<%= n %>" style="float:left; width:600px; position:relative;">
        <span class="o_contact o_contact<%= n %>" data-pos-x="<%= step.o_connection.pos_x %>" data-pos-y="<%= step.o_connection.pos_y %>"  data-pos-width="<%= step.o_connection.pos_width %>" data-pos-height="<%= step.o_connection.pos_height %>" id="spanid<%= n %>" data-image-width="<%= step.o_connection.image.dimensions.first %>" data-index="<%= n %>"> </span>
        <%= link_to image_tag(step.o_connection.image.image.url(:medium), id: "oconnection#{n}"), "#{step.o_connection.image.image.url(:large)}", class: "fancybox" %>
        <div class="o_tagmap<%= n %>"></div>
    </div>  
</div>              
</div>
4

1 回答 1

1

在您的 jQuery 中, .each 指的是跨度,因此在内部.each您需要遍历 DOM 才能访问图像。

由于图像似乎是跨度之后的直接兄弟,因此.next似乎是合适的(尽管可以使用许多其他方法):

$('span.i_contact').each(function() {    
    var imgWidth = parseInt($(this).data('image-width'));    
    console.log(imgWidth);
    if (imgWidth < 600) {
    var newWidth = ((imgWidth / 600) * 300)  
    alert(newWidth);
    $(this).next().css({
        "width":newWidth
    })    
}   
...
于 2013-08-08T14:08:57.100 回答