app-experiment-behavior
Polymer behavior for simple A/B/... experiments
[ This description is mirrored from README.md at github.com/Collaborne/app-experiment-behavior on 2019-05-22 ]
app-experiment-behavior
Polymer 1.x behavior for simple A/B/... experiments
Usage
See this blog post for a detailed tutorial.
Using this behavior is (fairly) easy:
bower install app-experiment-behavior
After that you need to reference the behavior and provide the viewer information for your component:
<dom-module is="experiment-component">
<template>
<style>
:host {
margin: 2em;
}
</style>
<div>[[_greeting]]</div>
</template>
<script>
// Simple example for how to set the oracle with a custom extraction function.
const oracle = Polymer.AppExperiment.Oracle.VIEWER_HASH(viewerId => viewerId);
Polymer({
is: 'experiment-component',
properties: {
experimentViewer: String,
_greeting: {
type: String,
computed: '_computeGreeting(experiment)'
}
},
behaviors: [
Polymer.AppExperiment.Behavior('experiment-component:greeting', [ 'world', 'universe' ], { oracle })
],
_computeGreeting(experiment) {
const greetings = {
'world': 'Hello, World!',
'universe': 'Jo, Universe!'
}
return greetings[experiment];
}
})
</script>
</dom-module>
In this example the component provides the 'experimentViewer' property directly, but this could be extracted into a separate behavior, allowing you to simplify code in your app even more:
const MyViewerBehavior = {
properties: {
experimentViewer: {
type: Object,
computed: '_computeExperimentViewer(...)'
},
},
_computeExperimentViewer(...) {
// Calculate the viewer based on the given inputs
}
};
function MyExperimentBehavior() {
return [...Polymer.AppExperimentBehavior.apply(this, arguments), MyViewerBehavior ];
}
Links
Compatibility
Was this helpful? Need more help?
Leave a comment or a question below. You can also join
the chat on Discord or
ask questions on StackOverflow.
Version
Dependencies
- polymer#Polymer/polymer#^2.0.0
- Released
- 2017-06-16
- Maturity
- IMPORTED
- License
- Apache License 2.0
Compatibility
- Framework
- Polymer 2.0+
- Polymer 1.0+ in 1.1.0
- Browser
- Browser Independent