本帖最后由 liwp 于 2020-7-27 12:07 编辑
1 i- ~4 `, B7 Q: ^1 Z* ?8 l# `, |% ~, }) _ M& `
wxml:
' A- y3 u/ z! f- <view class="comments_box" style="{{unfold?'max-height:'+GoodsInfo.reviewList.length*80+20+'rpx;':''}}">
( H6 ?8 b' B2 u9 E - <view class="unfoldText" wx:if="{{GoodsInfo.reviewList.length>1}}" bindtap="clickUnfold">{{unfoldText}}</view>2 G2 X' m8 E. d: F; X' @
- <block wx:for="{{GoodsInfo.reviewList}}" wx:key='index'>) ]/ W. d8 ], U' E V' {
- <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
- <view class="comments_box_list_left">{{item.ReviewAppellation}}</view>
0 Y( Y* _# G" \" G' U - <view class="comments_box_list_right">{{item.ReviewContent}}</view> 6 w, s. C$ p; x- w0 T; Z
- </view>
( B) w! g O/ I - </block> Z. P0 A9 {2 G6 o
- </view>
复制代码 wxss:/ ^6 s3 m7 r, L# f# @8 U
- .comments_box{# t3 t4 O; B5 I" R
- margin-top: 20rpx;! o2 Q, e! h# c* L
- width: 100%;- v! I* R; a5 P1 L
- overflow: hidden;: \% P D, h$ O
- transition: max-height 0.5s;/ C, ^7 }$ t& y: k
- overflow: hidden;
& d% _5 ~' h3 W; e: v& b* I0 R- [ - max-height: 105rpx;
6 s# y; ^, d" H2 A; p \, ?: k - }
复制代码 我这里是使用动画来控制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 |