php – 在foreach中按百分比定位

前端之家收集整理的这篇文章主要介绍了php – 在foreach中按百分比定位前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个现在看起来像这样的页面

并且代码是:

<?PHP
   $count_axle = $database->count_axles($_GET['train_id']);     
   foreach($count_axle as $counting){ 
}?>
    <div id="axle_bogie_border">
        <img id="count_train_image" src="Images/add_train1.png" alt="Train look" style="width:<?PHP echo $counting['totaldistance']; ?>%">
        <?PHP
                $show_axle = $database->axles($_GET['train_id']);
        ?>


        <div id="axle_position_count">
            <?PHP      
                foreach($show_axle as $axlefigure){ ?>
                    <div id="count_axle_figure" style="margin-left:<?PHP echo $counting['totaldistance']; ?>%"> 
                        <?PHP echo $axlefigure['axle'] ?>
                    </div>
            <?PHP
                } 
            ?><br /><br /><br />    
        </div>
    </div>

和CSS:

#axle_bogie_border {
    border: 2px solid black;
    width: 100%;
    height: auto;
    overflow-x: scroll;
    white-space: nowrap;
}

#count_train_image{
    margin-left: 10%;
    margin-right: 10%;
    height: 100px;
    display: inline-block;
    position: relative;
    float: left;
}


#show_length{
    border-bottom: 2px solid black;
    width: 100%;
}

#show_length2{
    border-bottom: 2px solid black;
    width: 10%;
}



#axle_position_count {
    margin-top: 10%;
    margin-left: 10%;
}

#count_axle_figure {
    background: black;
    width: 40px;
    height: 40px;
    border-radius: 50px;
    float: left;
}

对.所以我根据数据库的总和来制作图像的宽度.所以举个例子.您看到的每个圆圈(本例中为4个)都有距离.洙:

>轴1 = 2000
>轴2 = 8000
>轴3 = 2000
>轴4 = 8000

总共这是20.000mm 20.000mm = 20米.所以这列火车是20米.现在我将其缩小到percantages :(见图像宽度)

function count_axles($id) {
        $sql = "SELECT (sum(distance))/(25000)*(100) as totaldistance from axle WHERE train_id = :train_id";
        $sth = $this->pdo->prepare($sql);
        $sth->bindParam(":train_id",$id,PDO::PARAM_STR);
        $sth->execute();
        return $sth->fetchAll();
    }

在这里我告诉我100%是25.000毫米(25米).
现在我还需要这个用于轴位置.
因此,轴1 =例如总数的10%.所以我需要它在左边10%(保证金)
轴2 = 5%.所以我需要左边的轴1 5%= 15%.
等等

每个轴都有自己的ID(这里是DB图像)

所以最终我希望最终结果看起来像一个小火车. (因此前两个车轴左侧,最后两个车轴右侧)在火车图像下方.
像这样:

我不知道为什么有这么多人赞成这个问题.

对我来说似乎很不清楚.我无法得到什么问题?

我想唯一的问题是如何为车轴生成动态余量.

但即使这个问题也没有明确提出,预期结果也没有得到很好的描述.

所以这是我的猜测:

shift = -25; //my circle is 50px width 
             //so for the 1st axel if distance=0 
             //circle must be shifted to the left by -25px
viewWidth = 800;

axles = [{distance: 2000},{distance: 8000},{distance: 2000},{distance: 8000}];
trainWidth = 0;
axles.forEach(function (axle) {
  trainWidth += axle.distance;
});

width = Math.round(800*trainWidth/25000);

$('#train h2').text(""+(Math.round(trainWidth/10)/100)+"m");

unusedLeft = Math.round((viewWidth - width)/2);
unusedRight = unusedLeft;
$('#info .leftBox').width(""+unusedLeft+"px" );

unusedMeters = Math.round((25000-trainWidth)/10/2)/100;
$('#info .leftBox h3').text(""+unusedMeters+"m");
$('#info .rightBox h3').text(""+unusedMeters+"m");

$('#info .rightBox').width(""+unusedRight+"px" );

$('#train').width(""+width+"px" );

$('#axels').width(""+width+"px" );



idx = 0;
d = 0;
div = '';

axles.forEach(function (axle) {
  idx++;
  d += axle.distance;
  axle.idx = idx;
  margin = shift + Math.round(d*width/trainWidth);
  axle.margin = margin;
  div += '<div id="axel'+idx+'" style="margin-left: '+margin+'px ;" class="axel circle"></div>';
  
});

$('#axles').append(div);//.marginLeft(""+margin+"px");
h2,h3 {
  text-align:center;
  margin:2px auto;
}

.container {
  width:800px; 
  height:400px;
  border: solid 1px red;
}

#info {
  width:800px; 
  height:20px;
  border: none;
  position:relative;
}

#info .leftBox {
  left:0;
  top:0; 
  height:20px;
  width:75px;
  border-bottom: 1px solid blue;
  position:absolute;
}
#info .rightBox {
  right:0;
  top:0;
  height:20px;
  width:75px;
  border-bottom: 1px solid blue;
  position:absolute;
}
#train {
  margin:3px auto;
  width:650px;
  height:200px;
  background:black;
  vertical-align:middle;
  color:#FFFFFF;
}
#train h2{
  margin:auto auto;
  line-height:200px;
  color:#FFFFFF;
}

#axles {
  width:650px; 
  height:50px;
  margin: 1px auto;
  border: none;
  position:relative;
}

.axel {
	position: absolute;
  float:left;
}
.circle {
	width: 50px; height: 50px;
	border-radius: 50%;
	background: lightblue;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>


<div class="container">
  <h2>25m</h2>
  <hr />
  <div id="info">
    <div class="leftBox"><h3>2.5m</h3></div>
    <div class="rightBox"><h3>2.5m</h3></div>
  </div>
  <div id="train">
    <h2>20m</h2>
  </div>
  <div id="axles">
    

  </div>

现在只用JS完成,只是为了阐明如何设置元素的动态边距和宽度.

所以你只需要通过控制轴的值来玩这个片段,例如:

axles = [{distance: 2000},{distance: 2000}];

http://codepen.io/anon/pen/QbwRMJ

猜你在找的PHP相关文章