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


TypeScript ramda.pipe函數代碼示例

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


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

示例1:

const composeQuery = (word: string) => {
    const escapedWord = R.pipe(
        R.toLower,
        someSymbolsDelete,
        R.trim,
        fixDoubleSpaces,
        someSymbolsToHyphens
    )(word)

    const dictionaryUrl = `https://www.ldoceonline.com/dictionary/${escapedWord}`

    const queryUrl = `https://cors-anywhere.herokuapp.com/${dictionaryUrl}`

    return queryUrl
}
開發者ID:yakhinvadim,項目名稱:longman-to-anki,代碼行數:15,代碼來源:composeQuery.ts

示例2: splitBySelector

const extractDefinition = (senseMarkup: string) => {
    const definitionNodeMarkup = splitBySelector({
        selector: '.DEF',
        onlyChildren: true
    })(senseMarkup)[0]

    if (!definitionNodeMarkup) {
        return ''
    }

    const definition = R.pipe(
        domify,
        getTrimmedTextContent
    )(definitionNodeMarkup)

    return definition
}
開發者ID:yakhinvadim,項目名稱:longman-to-anki,代碼行數:17,代碼來源:extractDefinition.ts

示例3: extractHeadword

const composeWordData = (pageMarkup: string) => {
    const headword = extractHeadword(pageMarkup)
    const pronunciation = extractPronunciation(pageMarkup)
    const frequency = extractFrequency(pageMarkup)
    const entries = R.pipe(
        splitBySelector({ selector: '.ldoceEntry' }),
        R.map(composeEntryData)
    )(pageMarkup)

    const wordData = {
        headword,
        pronunciation,
        frequency,
        entries
    }

    return wordData
}
開發者ID:yakhinvadim,項目名稱:longman-to-anki,代碼行數:18,代碼來源:composeWordData.ts

示例4: clean

  static clean(required, strings, floats, data) {
    const rejectEmpty = R.reject(n => R.isEmpty(n[required]));

    const cleanStrings = R.map(n => {
      n[strings] = R.trim(n[strings]);
      return n;
    });

    const cleanFloats = R.map(n => {
      n[floats] = parseFloat(n[floats]);
      return n;
    });

    const clean = R.pipe(rejectEmpty,
      cleanStrings,
      cleanFloats
    );

    return clean(data);
  }
開發者ID:simbiosis-group,項目名稱:ion2-helper,代碼行數:20,代碼來源:array-helper.ts

示例5: forEach

  const doRequest = async axiosRequestConfig => {
    axiosRequestConfig.headers = {
      ...headers,
      ...axiosRequestConfig.headers,
    }

    // add the request transforms
    if (requestTransforms.length > 0) {
      // overwrite our axios request with whatever our object looks like now
      // axiosRequestConfig = doRequestTransforms(requestTransforms, axiosRequestConfig)
      forEach(transform => transform(axiosRequestConfig), requestTransforms)
    }

    // add the async request transforms
    if (asyncRequestTransforms.length > 0) {
      for (let index = 0; index < asyncRequestTransforms.length; index++) {
        const transform = asyncRequestTransforms[index](axiosRequestConfig)
        if (isPromise(transform)) {
          await transform
        } else {
          await transform(axiosRequestConfig)
        }
      }
    }

    // after the call, convert the axios response, then execute our monitors
    const chain = pipe(
      convertResponse(toNumber(new Date())),
      // partial(convertResponse, [toNumber(new Date())]),
      runMonitors,
    )

    return instance
      .request(axiosRequestConfig)
      .then(chain)
      .catch(chain)
  }
開發者ID:skellock,項目名稱:apisauce,代碼行數:37,代碼來源:apisauce.ts

示例6: normalize

}

const replaceBrackets = (str: string) => str.replace(/[{[<]/g, '(').replace(/[}\]>]/g, ')');
const replaceOperators = (str: string) =>
  str
    .replace(/[|/]/g, OPERATORS.or)
    .replace(/[;&]/g, OPERATORS.and)
    .replace(/ plus /g, OPERATORS.and)
    .replace(OPERATORS_REGEX, R.toLower);

export const normalize = R.pipe(
  removeSpaceFromModule,
  fixOperatorTypos,
  insertPostFixAsStandalone,
  convertCommas,
  R.curry(convertToNumerals)(1),
  replaceBrackets,
  fixBrackets,
  replaceOperators,
  removeModuleTitles,
);

export default function normalizeString(string: string, moduleCode: ModuleCode): string {
  // remove own module code from string (e.g. `CS1000R` would remove `CS1000R`, `CS1000`)
  // @ts-ignore Strings are lists, damn it
  const moduleWithoutPostfix = moduleCode.slice(0, R.findLastIndex(R.test(/\d/), moduleCode) + 1);
  const moduleRegex = new RegExp(`\\b${moduleWithoutPostfix}(?:[A-Z]|[A-Z]R)?\\b`, 'g');
  const preprocessed = string.replace(moduleRegex, '');
  return normalize(preprocessed);
}
開發者ID:nusmodifications,項目名稱:nusmods,代碼行數:30,代碼來源:normalizeString.ts

示例7:

 const updateFromBootsrapMessage = (data: BootstrapMessage) => 
   R.pipe<State, State, State>(
     R.assoc('boards', data.boards),
     R.assoc('notes', data.notes)
   )
開發者ID:JamesHageman,項目名稱:xstream-scrumbler,代碼行數:5,代碼來源:index.ts

示例8: pipe

import { pipe, curry } from 'ramda'

export const getRandom = (start, end) => start + Math.round(Math.random() * end)

export const jsonClone = pipe(
  JSON.stringify,
  JSON.parse
)

export const mutableAppend = curry((array, target) => {
  target.splice(target.length, 0, ...array)
  return target
})
開發者ID:NotBadDevs,項目名稱:minesweepers,代碼行數:13,代碼來源:utils.ts

示例9: pipe

import * as sauce from 'reduxsauce';
import { pipe, replace, toUpper } from 'ramda';

const RX_CAPS = /(?!^)([A-Z])/g;

const camelToScreamingSnake = pipe(
  replace(RX_CAPS, '_$1'),
  toUpper
);

export const createReducer = sauce.createReducer;

export const createActions = (actions) => {
  const { Creators: Actions } = sauce.createActions(actions);

  Object.keys(actions).forEach((key) => {
    Actions[key].toString = () => camelToScreamingSnake(key);
  });

  return Actions;
};
開發者ID:zanjs,項目名稱:wxapp-typescript,代碼行數:21,代碼來源:createActions.ts

示例10: fn

);

const summaryFile = fs.createWriteStream(path.resolve(projectPath, 'SUMMARY.md'));

type ContentConverter = (c: string) => string;

const convertContentWith = R.curry(
  (fn: ContentConverter, page: MarkdownPage) => R.merge(page, { content: fn(page.content) })
);

// string -> string
const convertionPineline = R.pipe(
  addToSummary(summaryFile),
  convertContentWith(decreaseHeaderLevel),
  convertContentWith(convertImgTag),
  convertContentWith(convertPlantUmlTag),
  convertContentWith(removeToc),
  convertContentWith(convertGist),
  convertContentWith(convertSwagger),
  addTitleAuthor,
);

// file -> void
// @ts-ignore waiting for @types/ramda update
const processMarkdown = R.pipeWith(R.then)([
  (file: string) => inName(['README', 'SUMMARY'], file)
    ? Promise.resolve(file) : moveToIndex(file),
  log('Convert'),
  convert(convertionPineline)
]);

// dir -> void
開發者ID:aleung,項目名稱:jekyll-to-gitbook,代碼行數:32,代碼來源:index.ts


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