當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript style-value-types.complex類代碼示例

本文整理匯總了TypeScript中style-value-types.complex的典型用法代碼示例。如果您正苦於以下問題:TypeScript complex類的具體用法?TypeScript complex怎麽用?TypeScript complex使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


在下文中一共展示了complex類的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: invariant

const createComplexAction: CreateVectorAction = (
  action,
  { from, to, ...props }
) => {
  const valueTemplate = complex.createTransformer(from);

  invariant(
    valueTemplate(from) === complex.createTransformer(to)(from),
    `Values '${from}' and '${to}' are of different format, or a value might have changed value type.`
  );

  return action({ ...props, from: 0, to: 1 }).pipe(
    blendArray(complex.parse(from), complex.parse(to)),
    valueTemplate
  );
};
開發者ID:jamesgeorge007,項目名稱:popmotion,代碼行數:16,代碼來源:vector.ts

示例2: if

const getActionCreator = (prop: any) => {
  // Pattern matching would be quite lovely here
  if (typeof prop === 'number') {
    return createAction;
  } else if (Array.isArray(prop)) {
    return createArrayAction;
  } else if (isUnitProp(prop)) {
    return createUnitAction;
  } else if (color.test(prop)) {
    return createColorAction;
  } else if (complex.test(prop)) {
    return createComplexAction;
  } else if (typeof prop === 'object') {
    return createObjectAction;
  } else {
    return createAction;
  }
};
開發者ID:Popmotion,項目名稱:popmotion,代碼行數:18,代碼來源:vector.ts

示例3: pipe

export const mixComplex = (origin: string, target: string): MixComplex => {
  const template = complex.createTransformer(target);
  const originStats = analyse(origin);
  const targetStats = analyse(target);

  // Test if both values have the same number of each value type (number/rgb/hsla), or that the origin
  // has the same or more numbers as the target, and throw if not.
  invariant(
    originStats.numHSL === targetStats.numHSL &&
      originStats.numRGB === targetStats.numRGB &&
      originStats.numNumbers >= targetStats.numNumbers,
    `Complex values '${origin}' and '${target}' too different to mix. Ensure all colors are of the same type.`
  );

  return pipe(
    mixArray(originStats.parsed, targetStats.parsed),
    template
  ) as MixComplex;
};
開發者ID:Popmotion,項目名稱:popmotion,代碼行數:19,代碼來源:mix-complex.ts

示例4: analyse

function analyse(value: string) {
  const parsed = complex.parse(value);
  const numValues = parsed.length;
  let numNumbers = 0;
  let numRGB = 0;
  let numHSL = 0;

  for (let i = 0; i < numValues; i++) {
    // Parsed complex values return with colors first, so if we've seen any number
    // we're already past that part of the array and don't need to continue running typeof
    if (numNumbers || typeof parsed[i] === 'number') {
      numNumbers++;
    } else {
      if ((parsed[i] as HSLA).hue !== undefined) {
        numHSL++;
      } else {
        numRGB++;
      }
    }
  }

  return { parsed, numNumbers, numRGB, numHSL };
}
開發者ID:Popmotion,項目名稱:popmotion,代碼行數:23,代碼來源:mix-complex.ts


注:本文中的style-value-types.complex類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。