召隆企博汇论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2403|回复: 0

小程序 如何在wxss中使用js里的变量?

[复制链接]

1

主题

3

回帖

144

积分

注册会员

Rank: 2

积分
144
发表于 2020-7-24 15:38:48 | 显示全部楼层 |阅读模式
本帖最后由 liwp 于 2020-7-27 12:07 编辑
1 i- ~4 `, B7 Q: ^1 Z* ?8 l# `, |% ~, }) _  M& `
wxml:
' A- y3 u/ z! f
  1. <view class="comments_box" style="{{unfold?'max-height:'+GoodsInfo.reviewList.length*80+20+'rpx;':''}}">
    ( H6 ?8 b' B2 u9 E
  2.     <view class="unfoldText" wx:if="{{GoodsInfo.reviewList.length>1}}" bindtap="clickUnfold">{{unfoldText}}</view>2 G2 X' m8 E. d: F; X' @
  3.     <block wx:for="{{GoodsInfo.reviewList}}" wx:key='index'>) ]/ W. d8 ], U' E  V' {
  4.         <view class="comments_box_list" style='transition: transform 300ms linear 0ms;transform: translateY(-{{unfold?0:((GoodsInfo.reviewList.length<1)?(index==0?(1-GoodsInfo.reviewList.length)*30:(1-GoodsInfo.reviewList.length+index)*30):index*30)}}rpx);'>2 G8 c3 m" _9 T; w' e
  5.             <view class="comments_box_list_left">{{item.ReviewAppellation}}</view>
    0 Y( Y* _# G" \" G' U
  6.             <view class="comments_box_list_right">{{item.ReviewContent}}</view> 6 w, s. C$ p; x- w0 T; Z
  7.         </view>
    ( B) w! g  O/ I
  8.     </block>   Z. P0 A9 {2 G6 o
  9. </view>
复制代码
wxss:/ ^6 s3 m7 r, L# f# @8 U
  1. .comments_box{# t3 t4 O; B5 I" R
  2.   margin-top: 20rpx;! o2 Q, e! h# c* L
  3.   width: 100%;- v! I* R; a5 P1 L
  4.   overflow: hidden;: \% P  D, h$ O
  5.   transition: max-height 0.5s;/ C, ^7 }$ t& y: k
  6.   overflow: hidden;
    & d% _5 ~' h3 W; e: v& b* I0 R- [
  7.   max-height: 105rpx;
    6 s# y; ^, d" H2 A; p  \, ?: k
  8. }
复制代码
我这里是使用动画来控制comments_box这个view的高度(max-height)变化时的过渡效果,我在wxss中给定固定值测试是可以实现效果的,但是因为这个view的高度是随数据变化的,所以我只能在wxml中通过GoodsInfo.reviewList的数组长度计算出高度之后赋值,结果测试后发现没有动画效果。* @1 {& u- S* E" w
所以我想在wxss中来使用GoodsInfo.reviewList的数组长度来计算高度,百度了一下,发现都是在wxml中使用的,跟我想要的不一样。
/ }+ s, f# L0 ?& g: U# E6 S, C3 s0 Y

7 M5 l( n0 O+ [: `6 C5 S* O% Z# `$ ^6 x
% X! K/ v9 |# n" ]
( d" m% @) c$ U/ }; u/ q- p4 S7 W
  r7 A0 {1 \* D; ^

( z3 d2 P+ @9 c; ^% ^% U0 W已解决:
& R" R( R3 ?9 [4 w6 z5 b. _
在开发过程中,通常碰到样式非固定的情况,这时候就要使用变量来规定样式,例如,一个view的宽度需要使用变量:
1. 在wxss中,定义变量:width:var(--width--);
2. 在js中,定义变量:viewWidth,并给这个变量赋予想要的值
3. 在xml中,使用wxss中的变量和js中的变量:style="--width--: {{ viewWidth }}px"

; j0 b, h, {7 S+ r( z9 M
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|召隆企博汇 ( 粤ICP备14061395号 )

GMT+8, 2026-3-15 22:24 , Processed in 0.050630 second(s), 25 queries .

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表