本帖最后由 liwp 于 2020-7-27 12:07 编辑 ; I7 m3 S! \! s2 ~: } D$ E6 z
7 d. K: C( p% s1 K1 c$ Zwxml:( H- W# L: Z2 t- i6 F& ~6 h
- <view class="comments_box" style="{{unfold?'max-height:'+GoodsInfo.reviewList.length*80+20+'rpx;':''}}">! D* p7 Q" }5 ?' m- D I4 [
- <view class="unfoldText" wx:if="{{GoodsInfo.reviewList.length>1}}" bindtap="clickUnfold">{{unfoldText}}</view>
& o- [; ~, E& ]" ?7 w% T8 n8 I - <block wx:for="{{GoodsInfo.reviewList}}" wx:key='index'>
- e! a3 }( l/ P9 _! O - <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);'>
& B) z+ F5 @- O - <view class="comments_box_list_left">{{item.ReviewAppellation}}</view>6 ?2 R* C" \ x6 o2 l% P: B
- <view class="comments_box_list_right">{{item.ReviewContent}}</view> ; |4 ? R) t* f8 H3 q4 D, M4 B$ r
- </view>
& L6 V8 Q! K8 K - </block>
5 z: W5 d) p8 L( s' j+ l - </view>
复制代码 wxss:
. a$ S( ]! ?- [4 h# P% j- .comments_box{
! l8 \8 N$ }( }6 l6 a5 N$ S. _& c - margin-top: 20rpx;
. a, y: w3 b/ Y4 m! ?$ G: b( N - width: 100%;4 Y$ M4 \. x: H" y0 z' r
- overflow: hidden;
) ^1 C$ [0 f- ?" l/ z - transition: max-height 0.5s;4 q0 H3 r. H9 n$ H8 o9 u% y: A) a
- overflow: hidden;
6 [4 i. ?2 U. k/ `3 x" N6 N - max-height: 105rpx;
/ V( }! h3 j, N# A1 F - }
复制代码 我这里是使用动画来控制comments_box这个view的高度(max-height)变化时的过渡效果,我在wxss中给定固定值测试是可以实现效果的,但是因为这个view的高度是随数据变化的,所以我只能在wxml中通过GoodsInfo.reviewList的数组长度计算出高度之后赋值,结果测试后发现没有动画效果。
8 D" k, R3 N6 r. S所以我想在wxss中来使用GoodsInfo.reviewList的数组长度来计算高度,百度了一下,发现都是在wxml中使用的,跟我想要的不一样。6 b4 u% b- Q& e4 I8 a
9 q% ^- k m1 _) B
8 A6 [* P3 A" B D
0 @9 ?) B1 S" |' A2 @: a4 I" }3 i& t+ p1 D: o0 z5 R
0 r- M3 s$ M+ ]" T! |* M
9 l0 @; U# M) K! b7 N1 H
. t B z5 @5 |! d: \- e
已解决:
5 A2 O5 {! ^/ T! ?$ y C' }* }在开发过程中,通常碰到样式非固定的情况,这时候就要使用变量来规定样式,例如,一个view的宽度需要使用变量: 1. 在wxss中,定义变量:width:var(--width--); 2. 在js中,定义变量:viewWidth,并给这个变量赋予想要的值 3. 在xml中,使用wxss中的变量和js中的变量:style="--width--: {{ viewWidth }}px"
# \& t# }: a. G2 n+ K! u( b |